Git 分支管理和沖突解決

創建分支

  git branch

  沒有參數,顯示本地版本庫中所有的本地分支名稱。

  當前檢出分支的前面會有星號。

  git branch newname

  在當前檢出分支上新建分支,名叫newname。

  git checkout newname

  檢出分支,即切換到名叫newname的分支。

  git checkout –b newname master

  這個命令將上面兩個命令合并:在master分支上創建分支newname分支并檢出到該分支。

?

合并分支間的修改 Merge

  合并操作將兩條或多條分支合并到一起,實際上有好幾種分支合并方法,下面介紹主要的三種:

  1.直接合并(straight merge)

  把兩條分支上的歷史軌跡合并,交匯到一起。

  比如要把dev分支上的所有東東合并到master分支:

  首先先到master分支:git checkout master

  然后把dev給合并過來:git merge dev

  注意沒參數的情況下merge是fast-forward的,即Git將master分支的指針直接移到dev的最前方。

  換句話說,如果順著一個分支走下去可以到達另一個分支的話,那么Git在合并兩者時,只會簡單移動指針,所以這種合并成為快進式(Fast-forward)

?

  2.壓合合并(squashed commits):

  將一條分支上的若干個提交條目壓合成一個提交條目,提交到另一條分支的末梢。

  把dev分支上的所有提交壓合成主分支上的一個提交,即壓合提交:

  3.揀選合并(cherry-picking):

  揀選另一條分支上的某個提交條目的改動帶到當前分支上。

  每一次提交都會產生一個全局唯一的提交名稱,利用這個名稱就可以進行揀選提交。

  比如在dev上的某個提交叫:321d76f

  把它合并到master中:

  git checkout master

  git cherry-pick 321d76f

  要揀選多個提交,可以給git cherry-pick命令傳遞-n選項,比如:

  git cherry-pick –n 321d76f

  這樣在揀選了這個改動之后,進行暫存而不立即提交,接著可以進行下一個揀選操作,一旦揀選完需要的各個提交,就可以一并提交。

?

沖突處理

  當兩條分支對同一個文件的同一個文本塊進行了不同的修改,并試圖合并時,Git不能自動合并的,稱之為沖突(conflict)。解決沖突需要人工處理。

  比如當前在master分支,想把dev分支merge過來,結果產生了一個沖突,打開文件內容可以看到這么一個沖突:

復制代碼
<<<<<<< HEADtest in master=======test in dev>>>>>>> dev
復制代碼

??

  <<<<<<<標記沖突開始,后面跟的是當前分支中的內容。

  HEAD指向當前分支末梢的提交。

  =======之后,>>>>>>>之前是要merge過來的另一條分支上的代碼。

  >>>>>>>之后的dev是該分支的名字。

  對于簡單的合并,手工編輯,然后去掉這些標記,最后像往常的提交一樣先add再commit即可。

?

刪除分支

  有些分支沒有必要長期保存,比如分支中的代碼已經打了標簽并已發布,或者實驗分支已經成功完成工作或中途廢棄等等。?

  注意:打了標簽的分支,Git在刪除該分支時,從版本樹起始到此標簽間的全部歷史軌跡均會保留,此時刪除分支操作只是刪除分支本身的名稱,因此可以說該分支沒有必要長期保存。

  而在其他版本控制工具中,刪除分支通常意味著刪除分支上的所有歷史軌跡,所以不能因為打了標簽就認為其沒有必要保存。

?

  刪除一個分支dev2:

    進行強刪。

?

分支重命名

  重命名分支:

  git branch –m oldname newname

  -m不會覆蓋已有分支名稱,即如果名為newname的分支已經存在,則會提示已經存在了。

  如果改成-M就可以覆蓋已有分支名稱了,即會強制覆蓋名為newname的分支,這種操作要謹慎。

-----------------------------------------------------------

來源于:http://www.cnblogs.com/mengdd/p/3585038.html

?

轉載于:https://www.cnblogs.com/dingyingsi/p/4757246.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/374585.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/374585.shtml
英文地址,請注明出處:http://en.pswp.cn/news/374585.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

力扣打開轉盤鎖

打開轉盤鎖 評論區大神代碼&#xff1a; public int openLock(String[] deadends, String target) {Set<String> set new HashSet<>(Arrays.asList(deadends));//開始遍歷的字符串是"0000"&#xff0c;相當于根節點String startStr "0000";i…

EJB程序化查找

在上一篇文章中&#xff0c;我們了解了EJB 引用和EJB 注入 。 盡管EJB注入是一種強大的容器工具&#xff0c;可以簡化模塊化應用程序的開發&#xff0c;但有時還是需要執行程序化EJB查找。 讓我們假設&#xff0c;例如&#xff0c;一組不同的EJB實現了由公共業務接口定義的公共…

git克隆/更新/提交代碼步驟及示意圖

1. git clone ssh://flycm.intel.com/scm/at/atSrc 或者git clone ssh://flycm.intel.com/scm/at/atJar 或者git clone ssh://flycm.intel.com/scm/at/atFramework 2. git checkout cpeg/scm/stable 切換分支&#xff0c;然后更新代碼 3. git pull 先把遠程分支上最新的代碼拉到…

C++面試寶典

1.new、delete、malloc、free關系 delete會調用對象的析構函數,和new對應free只會釋放內存&#xff0c;new調用構造函數。malloc與free是C/C語言的標準庫函數&#xff0c;new/delete是C的運算符。它們都可用于申請動態內存和釋放內存。對于非內部數據類型的對象而言&#xff0c…

Google App Engine:在您自己的域中托管應用程序

在Google App Engine中創建新應用程序時&#xff0c;您將獲得一個域名“ yourapp.appspot.com”。 但是&#xff0c;誰會想要以這樣的后綴托管他們的應用程序&#xff08;除非您喜歡它&#xff01;&#xff09;&#xff1f; 為了改善您的應用品牌&#xff0c;最好的辦法是將您的…

從零開始學 iOS 開發的15條建議

事情困難是事實&#xff0c;再困難的事還是要每天努力去做是更大的事實。 因為我是一路自學過來的&#xff0c;并且公認沒什么天賦的前提下&#xff0c;進步得不算太慢&#xff0c;所以有很多打算從零開始的朋友會問我&#xff0c;該怎么學iOS開發。跟粉絲群的朋友交流了一下&a…

垂直居中-父元素高度確定的多行文本(方法二)

除了上一節講到的插入table標簽&#xff0c;可以使父元素高度確定的多行文本垂直居中之外&#xff0c;本節介紹另外一種實現這種效果的方法。但這種方法兼容性比較差&#xff0c;只是提供大家學習參考。 在 chrome、firefox 及 IE8 以上的瀏覽器下可以設置塊級元素的 display 為…

13. 羅馬數字轉整數

羅馬數字轉整數 class Solution {public int romanToInt(String s) {Map<Character,Integer> map new HashMap<Character,Integer>(){{put(I,1);put(V,5);put(X,10);put(L,50);put(C,100);put(D,500);put(M,1000);}};int res 0;for(int i 0;i<s.length();i)…

互聯網金融P2P主業務場景自動化測試

互聯網金融P2P行業&#xff0c;近三年來發展迅速&#xff0c;如火如荼。據不完全統計&#xff0c;全國有3000的企業。“互聯網”企業&#xff0c;幾乎每天都會碰到一些奇奇怪怪的bug&#xff0c;作為在互聯網企業工作的測試人員&#xff0c;風險和壓力都巨大。那么我們如何降低…

OSGi將Maven與Equinox結合使用

很長時間以來&#xff0c;我一直在努力理解OSGi的真正含義。 它已經存在很長時間了&#xff0c;但是沒有多少人意識到這一點。 人們已經大肆宣傳它是一種非常復雜的技術。 這是我為所有Java開發人員簡化的嘗試。 簡而言之&#xff0c; OSGi是一組規范&#xff0c;這些規范允許對…

note05-計算機網絡

5.網絡安全 被動攻擊(UDP報文被截獲 被 進行流量分析) 主動攻擊 1.篡改(更改報文流 偽報文) 2.惡意程序(病毒、木馬、蠕蟲、炸彈) 3.拒絕服務Dos 密碼體制 1.對稱密鑰密碼體制(DES IDEA) 即加密和解密的密鑰K相同 2.公鑰密碼體制(RSA) A加密使用PKB公鑰 B解密使用對應的私鑰SK…

825. 適齡的朋友

適齡的朋友 在社交媒體網站上有 n 個用戶。給你一個整數數組 ages &#xff0c;其中 ages[i] 是第 i 個用戶的年齡。 如果下述任意一個條件為真&#xff0c;那么用戶 x 將不會向用戶 y&#xff08;x ! y&#xff09;發送好友請求&#xff1a; age[y] < 0.5 * age[x] 7 ag…

struts2設置文件上傳大小

利用struts2想要設置或者限制上傳文件的大小,可以在struts.xml配置文件里面進行如下配置: <constant name"struts.multipart.maxSize" value"10000000" /> 上面這句話的意思是設置文件上傳大小&#xff0c;最大不超過9.8M。計算方式如下&#xff1a;…

Java命名約定

我想寫這篇簡短的文章來幫助某些難以記住Java API類和方法名稱的人。 如您所知&#xff0c;Java是區分大小寫的語言&#xff0c;要構建Java程序&#xff0c;您需要使用許多內置API類和方法。 而且&#xff0c;初學者發現很難準確地記住方法名稱和類名稱而不改變大小寫。 但是實…

smarty引擎之練習

關于smarty最直觀的感受就是分離了頁面中html和php的代碼&#xff0c;頁面不再混亂&#xff0c;很清晰了…… smarty->assign();//注冊 smarty->display();//加載模板 除了老師給的表&#xff0c;kemu,nandu,type都建了表格&#xff0c;便于使用 main.php <?phpinclu…

Heron 論文翻譯及理解

Heron 論文翻譯及理解 背景介紹&#xff1a; Heron是號稱Twitter流數據處理的新一代實現&#xff0c;是StormV2。我們首先回顧一下Storm系統的問題 worker日志混亂&#xff0c;如果一個bolt日志過大&#xff0c;會沖掉其他bolt的日志worker之間因為沒有資源隔離&#xff0c;因此…

1688比賽中的配對次數

給你一個整數 n &#xff0c;表示比賽中的隊伍數。比賽遵循一種獨特的賽制&#xff1a; 如果當前隊伍數是 偶數 &#xff0c;那么每支隊伍都會與另一支隊伍配對。總共進行 n / 2 場比賽&#xff0c;且產生 n / 2 支隊伍進入下一輪。 如果當前隊伍數為 奇數 &#xff0c;那么將…

Hadoop:簡單介紹

什么是Hadoop&#xff1a; Hadoop是一種用Java編寫的框架&#xff0c;用于在大型商品硬件集群上運行應用程序&#xff0c;并具有類似于Google File System和MapReduce的功能 。 HDFS是高度容錯的分布式文件系統&#xff0c;與Hadoop一樣&#xff0c;旨在部署在低成本硬件上。 它…

PHP中__get()和__set()的用法實例詳

剛剛看到一個對我有用的文章&#xff0c;我就把它摘抄下來了。 php面向對象_get(),_set()的用法 一般來說&#xff0c;總是把類的屬性定義為private&#xff0c;這更符合現實的邏輯。但是&#xff0c;對屬性的讀取和賦值操作是非常頻繁的&#xff0c;因此在PHP5中&#xff0…

Javascript 異步編程的4種方法

你可能知道&#xff0c;Javascript語言的執行環境是"單線程"&#xff08;single thread&#xff09;。 所謂"單線程"&#xff0c;就是指一次只能完成一件任務。如果有多個任務&#xff0c;就必須排隊&#xff0c;前面一個任務完成&#xff0c;再執行后面一…