當(dāng)前位置:首頁(yè) >  站長(zhǎng) >  編程技術(shù) >  正文

詳解git merge命令應(yīng)用的三種情景

 2020-11-18 15:37  來源: 腳本之家   我來投稿 撤稿糾錯(cuò)

  域名預(yù)訂/競(jìng)價(jià),好“米”不錯(cuò)過

這篇文章主要介紹了詳解git merge命令應(yīng)用的三種情景,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

一、git merge 命令應(yīng)用的三種情景

1.1 “快進(jìn)”(無沖突)

master分支

假設(shè)現(xiàn)在只有一個(gè)默認(rèn)的 master 分支,并提交了3次,B0、B1和B2都是提交對(duì)象。

首先要清楚,每次產(chǎn)生的提交對(duì)象會(huì)包含一個(gè)指向上次提交對(duì)象(父對(duì)象)的指針,所以圖中B0、B1和B2之間的箭頭是指針指向父對(duì)象的意思,真正的提交順序還是B0到B1再到B2。同時(shí) master 指針指向最新的提交B2。

另外Git中還有一個(gè)名為 HEAD 的特殊指針,它是一個(gè)指針,指向當(dāng)前所在的本地分支(可以將 HEAD想象為當(dāng)前分支的別名)。

dev新分支

現(xiàn)在新建一個(gè)分支并切換到新分支。

$ git checkout -b dev
Switched to a new branch 'dev'

它是下面兩條命令的簡(jiǎn)寫:

$ git branch dev
$ git checkout dev

因?yàn)槭窃贐2創(chuàng)建 dev,所以新分支 dev 指向B2。另外從分支 master 切換到分支 dev,所以HEAD指向當(dāng)前分支 dev。

在 dev 分支工作并提交了2次:

合并dev和master

在分支 dev 的工作結(jié)束,切換到分支 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(-)

由于當(dāng)前 master 分支所指向的提交是你當(dāng)前提交(dev的提交)的直接上游,所以 Git 只是簡(jiǎn)單的將 master 指針向前移動(dòng)。 換句話說,當(dāng)你試圖合并兩個(gè)分支時(shí),如果順著一個(gè)分支走下去能夠到達(dá)另一個(gè)分支,那么 Git 在合并兩者的時(shí)候,只會(huì)簡(jiǎn)單的將指針向前推進(jìn)(指針右移),因?yàn)檫@種情況下的合并操作沒有需要解決的分歧——這就叫做 “快進(jìn)(fast-forward)”。合并結(jié)果如下:

最后,你可以刪除 dev 分支,因?yàn)槟阋呀?jīng)不再需要它了 —— master 分支已經(jīng)指向了同一個(gè)位置。 你可以使用帶 -d 選項(xiàng)的 git branch 命令來刪除分支:

$ git branch -d dev

1.2 非“快進(jìn)”,修改不同文件。(無沖突)

當(dāng)在新分支 dev 進(jìn)行了一次提交B3,再回到分支 master 又進(jìn)行一次提交 B4。

這里用 git merge 合并分為兩種情況,現(xiàn)在講第一種情況:

在 master 分支和 dev 分支的公共祖先 B2 后,master 和 dev 的提交是對(duì)不同文件或者同一文件的不同部分進(jìn)行了修改,Git 可以合并它們。(比如說原來有 test-1 和 test-2 兩個(gè)文件,B4修改的是 test-1 文件,而B3修改的是 test-2 文件,然后合并兩個(gè)分支。)

$ 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(-)

合并是成功的。

出現(xiàn)這種情況的時(shí)候,Git 會(huì)使用兩個(gè)分支的末端所指的快照(B3 和 B4)以及這兩個(gè)分支的公共祖先(B2),做一個(gè)簡(jiǎn)單的三方合并。注意這里合并后 master 自動(dòng) commit 提交了一次,產(chǎn)生了提交B5。而B5中的結(jié)果是三方合并的結(jié)果。合并結(jié)果如下:

最后,合并完成,你已經(jīng)不再需要dev分支了。 現(xiàn)在你可以刪除這個(gè)分支。

$ git branch -d dev

1.3 非“快進(jìn)”,修改相同文件。(有沖突)

當(dāng)在新分支 dev 進(jìn)行了一次提交B3,再回到分支 master 又進(jìn)行一次提交 B4。

上面講的是第一種情況,現(xiàn)在講第二種情況:

在 master 分支和 dev 分支的公共祖先 B2 后,master 和 dev 的提交是對(duì)同一個(gè)文件的同一個(gè)部分進(jìn)行了不同的修改,Git 就沒法干凈的合并它們。(比如說原來有 test-1 和 test-2 兩個(gè)文件,B4修改的是 test-1 文件,而B3修改的也是 test-1 文件的同一部分,然后合并兩個(gè)分支。)

$ 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.

合并是失敗的。

此時(shí) Git 做了合并,但是沒有自動(dòng)地創(chuàng)建一個(gè)新的合并提交。 Git 會(huì)暫停下來,等待你去解決合并產(chǎn)生的沖突。 你可以在合并沖突后的任意時(shí)刻使用 git status 命令來查看那些因包含合并沖突而處于未合并(unmerged)狀態(tài)的文件:

$ 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")

任何因包含合并沖突而有待解決的文件,都會(huì)以未合并狀態(tài)標(biāo)識(shí)出來。 Git 會(huì)在有沖突的文件中加入標(biāo)準(zhǔn)的沖突解決標(biāo)記,這樣你可以打開這些包含沖突的文件然后手動(dòng)解決沖突。 出現(xiàn)沖突的文件會(huì)包含一些特殊區(qū)段,看起來像下面這個(gè)樣子:

This is test-1.
update test-1.
add test-1.
<<<<<<< HEAD
test master.
=======
test dev.
>>>>>>> dev

這里 HEAD 表示所指示的版本(也就是你的 master 分支所在的位置,因?yàn)槟阍谶\(yùn)行 merge 命令的時(shí)候已經(jīng)檢出到了這個(gè)分支)在這個(gè)區(qū)段的上半部分(======= 的上半部分),而 dev 分支所指示的版本在 ======= 的下半部分。 為了解決沖突,你必須選擇使用由 ======= 分割的兩部分中的一個(gè),或者你也可以自行合并這些內(nèi)容。 例如,你可以通過把這段內(nèi)容換成下面的樣子來解決沖突:

This is test-1.
update test-1.
add test-1.
test master.
test dev.

然后手動(dòng)提交:

$ git add .
$ git commit -m "connection"
[master f7daa6b] connection

然后沖突就解決了。合并結(jié)果如下:

最后,合并完成,你已經(jīng)不再需要dev分支了。 現(xiàn)在你可以刪除這個(gè)分支。

$ git branch -d dev

到此這篇關(guān)于詳解git merge命令應(yīng)用的三種情景的文章就介紹到這了,更多相關(guān)git merge命令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

文章轉(zhuǎn)自腳本之家,原文鏈接:https://www.jb51.net/article/192812.htm

申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

相關(guān)標(biāo)簽
git使用的基本流程

相關(guān)文章

熱門排行

信息推薦