git merge 與 git rebase的區別

前言

其實這個問題困擾我有一段時間,相信也有人和我一樣有這個困擾,網上已有很多這種解釋了,但是要么就是無圖,要么就是解釋的很亂,沒太看懂,經過自己對git的使用,加上向同事請教,算是理解了這個問題,所以寫下來分享一下,我盡量詳細說明

merge與rebase的區別

假設我們有如下圖一所示倉庫,該倉庫有master和develop兩個分支,且develop是在(3.added merge.txt file)commit處從master拉出來的分支。

圖一
merge

假設現在HEAD在(6.added hello.txt file)處,也就是在master分支最近的一次提交處,此時執行git merge develop, 結果如下圖所示。

圖二

工作原理就是:git 會自動根據兩個分支的共同祖先即 (3.added merge.txt file)這個 commit 和兩個分支的最新提交即 (6.added hello.txt file) 和 (5.added test.txt file) 進行一個三方合并,然后將合并中修改的內容生成一個新的 commit,即圖二的(7.Merge branch ‘develop’)。
這是merge的效果,簡單來說就合并兩個分支并生成一個新的提交。

rebase

那rebase是這么工作的呢?
假設初始狀態也是圖一所顯示的。兩個分支一個master,一個develop,此時HEAD在(6.added hello.txt file)處,現在執行git rebase develop,結果如下圖三所示。

圖三

可以看見develop分支分出來分叉不見了,下面來解釋一下它的工作原理:
在執行git rebase develop之前,HEAD在(6.added hello.txt file)處,當執行rebase操作時,git 會從兩個分支的共同祖先 (3.added merge.txt file)開始提取 當前分支(此時是master分支)上的修改,即 (6.added hello.txt file)這個commit,再將 master 分支指向 目標分支的最新提交(此時是develop分支)即(5.added test.txt file) 處,然后將剛剛提取的修改應用到這個最新提交后面。如果提取的修改有多個,那git將依次應用到最新的提交后面,如下兩圖所示,圖四為初始狀態,圖五為執行rebase后的狀態。

圖四
圖五

簡單來說,git rebase提取操作有點像git cherry-pick一樣,執行rebase后依次將當前的提交cherry-pick到目標分支上,然后將在原始分支上的已提取的commit刪除。

merge OR rebase

那什么時候用merge,什么時候用rebase呢?
再舉個例子:
初始狀態如下圖六所示:
和之前一樣的是,develop分支也是在 (3.added merge.txt file)處從master分支拉取develop分支。不一樣的是兩個分支各個commit的時間不同,之前develop分支的4和5commit在master分支3之后6之前,現在是develop分支的4提交早于master分支的5提交,develop分支的6提交晚于master的5提交早于master的7提交。

圖六

在上圖情況下,在master分支的7commit處,執行git merge develop,結果如下圖七所示:

圖七

執行git rebase develop,結果如下圖八所示:

圖八

1. 可以看出merge結果能夠體現出時間線,但是rebase會打亂時間線。
2. 而rebase看起來簡潔,但是merge看起來不太簡潔。
3. 最終結果是都把代碼合起來了,所以具體怎么使用這兩個命令看項目需要。

還有一點說明的是,在項目中經常使用git pull來拉取代碼,git pull相當于是git fetch + git merge,如果此時運行git pull -r,也就是git pull –rebase,相當于git fetch + git rebase

最后推薦一些git可視化工具,我用的是gitkraken,這些工具功能基本一樣,看個人喜歡好使用

鳴謝:感謝我的同事張帆同學在git方面的指導

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 重讀數字設計經典,估計要讀一個月的樣子。 用戶體驗三個重要關注點,行為,內容,形態。 要理解目標和任務的區別。不僅...
    Binner閱讀 526評論 0 51
  • 我覺得確實還是要對所學的東西進行熟悉熟悉,再熟悉,因為熟悉了以后,你就會掌握里面的比較高級的比較深入的一些法則和一...
    智囊團閱讀 72評論 0 0
  • 耶瓜閱讀 254評論 0 0
  • 職場:職場上能交到朋友是幸運,交不到朋友才是正常。你工作是來賺錢的,不是來交朋友的,沒有永遠的朋友,只有永遠的利益...
    江尺瀾依閱讀 226評論 0 0
  • 使用簡書是因為參加百日理財小組需要提交作業,小組長建議用簡書,所以我在上面寫了幾篇理財的作業,沒想到得到了一些小伙...
    曉茜自留地閱讀 326評論 0 4