您好,登錄后才能下訂單哦!
這篇文章運用簡單易懂的例子給大家介紹merge命令在git 中的使用場景有哪些,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
一、git merge 命令應用的三種情景
1.1 “快進”(無沖突)
master分支
假設現在只有一個默認的 master 分支,并提交了3次,B0、B1和B2都是提交對象。
首先要清楚,每次產生的提交對象會包含一個指向上次提交對象(父對象)的指針,所以圖中B0、B1和B2之間的箭頭是指針指向父對象的意思,真正的提交順序還是B0到B1再到B2。同時 master 指針指向最新的提交B2。
另外Git中還有一個名為 HEAD 的特殊指針,它是一個指針,指向當前所在的本地分支(可以將 HEAD想象為當前分支的別名)。
dev新分支
現在新建一個分支并切換到新分支。
$ git checkout -b dev Switched to a new branch 'dev'
它是下面兩條命令的簡寫:
$ git branch dev $ git checkout dev
因為是在B2創建 dev,所以新分支 dev 指向B2。另外從分支 master 切換到分支 dev,所以HEAD指向當前分支 dev。
在 dev 分支工作并提交了2次:
合并dev和master
在分支 dev 的工作結束,切換到分支 master ,然后把 dev 合并到 master 上:
$ git checkout master Switched to branch 'master' $ git merge dev Merge made by the 'recursive' strategy. test-2.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-)
由于當前 master 分支所指向的提交是你當前提交(dev的提交)的直接上游,所以 Git 只是簡單的將 master 指針向前移動。 換句話說,當你試圖合并兩個分支時,如果順著一個分支走下去能夠到達另一個分支,那么 Git 在合并兩者的時候,只會簡單的將指針向前推進(指針右移),因為這種情況下的合并操作沒有需要解決的分歧——這就叫做 “快進(fast-forward)”。合并結果如下:
最后,你可以刪除 dev 分支,因為你已經不再需要它了 —— master 分支已經指向了同一個位置。 你可以使用帶 -d 選項的 git branch 命令來刪除分支:
$ git branch -d dev
1.2 非“快進”,修改不同文件。(無沖突)
當在新分支 dev 進行了一次提交B3,再回到分支 master 又進行一次提交 B4。
這里用 git merge 合并分為兩種情況,現在講第一種情況:
在 master 分支和 dev 分支的公共祖先 B2 后,master 和 dev 的提交是對不同文件或者同一文件的不同部分進行了修改,Git 可以合并它們。(比如說原來有 test-1 和 test-2 兩個文件,B4修改的是 test-1 文件,而B3修改的是 test-2 文件,然后合并兩個分支。)
$ git checkout master Switched to branch 'master' $ git merge dev Merge made by the 'recursive' strategy. test-2.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-)
合并是成功的。
出現這種情況的時候,Git 會使用兩個分支的末端所指的快照(B3 和 B4)以及這兩個分支的公共祖先(B2),做一個簡單的三方合并。注意這里合并后 master 自動 commit 提交了一次,產生了提交B5。而B5中的結果是三方合并的結果。合并結果如下:
最后,合并完成,你已經不再需要dev分支了。 現在你可以刪除這個分支。
$ git branch -d dev
1.3 非“快進”,修改相同文件。(有沖突)
當在新分支 dev 進行了一次提交B3,再回到分支 master 又進行一次提交 B4。
上面講的是第一種情況,現在講第二種情況:
在 master 分支和 dev 分支的公共祖先 B2 后,master 和 dev 的提交是對同一個文件的同一個部分進行了不同的修改,Git 就沒法干凈的合并它們。(比如說原來有 test-1 和 test-2 兩個文件,B4修改的是 test-1 文件,而B3修改的也是 test-1 文件的同一部分,然后合并兩個分支。)
$ git checkout master Switched to branch 'master' $ git merge dev Auto-merging test-1.txt CONFLICT (content): Merge conflict in test-1.txt Automatic merge failed; fix conflicts and then commit the result.
合并是失敗的。
此時 Git 做了合并,但是沒有自動地創建一個新的合并提交。 Git 會暫停下來,等待你去解決合并產生的沖突。 你可以在合并沖突后的任意時刻使用 git status 命令來查看那些因包含合并沖突而處于未合并(unmerged)狀態的文件:
$ git status On branch master You have unmerged paths. (fix conflicts and run "git commit") (use "git merge --abort" to abort the merge) Unmerged paths: (use "git add <file>..." to mark resolution) both modified: test-1.txt no changes added to commit (use "git add" and/or "git commit -a")
任何因包含合并沖突而有待解決的文件,都會以未合并狀態標識出來。 Git 會在有沖突的文件中加入標準的沖突解決標記,這樣你可以打開這些包含沖突的文件然后手動解決沖突。 出現沖突的文件會包含一些特殊區段,看起來像下面這個樣子:
This is test-1. update test-1. add test-1. <<<<<<< HEAD test master. ======= test dev. >>>>>>> dev
這里 HEAD 表示所指示的版本(也就是你的 master 分支所在的位置,因為你在運行 merge 命令的時候已經檢出到了這個分支)在這個區段的上半部分(======= 的上半部分),而 dev 分支所指示的版本在 ======= 的下半部分。 為了解決沖突,你必須選擇使用由 ======= 分割的兩部分中的一個,或者你也可以自行合并這些內容。 例如,你可以通過把這段內容換成下面的樣子來解決沖突:
This is test-1. update test-1. add test-1. test master. test dev.
然后手動提交:
$ git add . $ git commit -m "connection" [master f7daa6b] connection
然后沖突就解決了。合并結果如下:
最后,合并完成,你已經不再需要dev分支了。 現在你可以刪除這個分支。
$ git branch -d dev
關于merge命令在git 中的使用場景有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。