濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 詳解git merge 與 git rebase的區(qū)別

詳解git merge 與 git rebase的區(qū)別

熱門標(biāo)簽:地圖標(biāo)注項(xiàng)目幾個(gè)月 谷歌地圖標(biāo)注日期 鶴壁高頻外呼系統(tǒng)多少錢一個(gè)月 蘇州呼叫中心外呼系統(tǒng)哪家強(qiáng) 外呼系統(tǒng)怎么群發(fā)短信 400電話申請(qǐng)到底哪家好 聯(lián)通外呼系統(tǒng)電腦app軟件 宿遷怎么辦理400電話 400電話辦理費(fèi)用低

前言

      其實(shí)這個(gè)問(wèn)題困擾我有一段時(shí)間,相信也有人和我一樣有這個(gè)困擾,網(wǎng)上已有很多這種解釋了,但是要么就是無(wú)圖,要么就是解釋的很亂,沒(méi)太看懂,經(jīng)過(guò)自己對(duì)git的使用,加上向同事請(qǐng)教,算是理解了這個(gè)問(wèn)題,所以寫下來(lái)分享一下,我盡量詳細(xì)說(shuō)明

merge與rebase的區(qū)別

        假設(shè)我們有如下圖一所示倉(cāng)庫(kù),該倉(cāng)庫(kù)有master和develop兩個(gè)分支,且develop是在(3.added merge.txt file)commit處從master拉出來(lái)的分支。  


merge

        假設(shè)現(xiàn)在HEAD在(6.added hello.txt file)處,也就是在master分支最近的一次提交處,此時(shí)執(zhí)行g(shù)it merge develop, 結(jié)果如下圖所示。 


         工作原理就是:git 會(huì)自動(dòng)根據(jù)兩個(gè)分支的共同祖先即 (3.added merge.txt file)這個(gè) commit 和兩個(gè)分支的最新提交即 (6.added hello.txt file) 和 (5.added test.txt file) 進(jìn)行一個(gè)三方合并,然后將合并中修改的內(nèi)容生成一個(gè)新的 commit,即圖二的(7.Merge branch ‘develop')。 

        這是merge的效果,簡(jiǎn)單來(lái)說(shuō)就合并兩個(gè)分支并生成一個(gè)新的提交。

rebase

      那rebase是這么工作的呢? 

      假設(shè)初始狀態(tài)也是圖一所顯示的。兩個(gè)分支一個(gè)master,一個(gè)develop,此時(shí)HEAD在(6.added hello.txt file)處,現(xiàn)在執(zhí)行g(shù)it rebase develop,結(jié)果如下圖三所示。 


        可以看見develop分支分出來(lái)分叉不見了,下面來(lái)解釋一下它的工作原理: 

         在執(zhí)行g(shù)it rebase develop之前,HEAD在(6.added hello.txt file)處,當(dāng)執(zhí)行rebase操作時(shí),git 會(huì)從兩個(gè)分支的共同祖先 (3.added merge.txt file)開始提取 當(dāng)前分支(此時(shí)是master分支)上的修改,即 (6.added hello.txt file)這個(gè)commit,再將 master 分支指向 目標(biāo)分支的最新提交(此時(shí)是develop分支)即(5.added test.txt file) 處,然后將剛剛提取的修改應(yīng)用到這個(gè)最新提交后面。如果提取的修改有多個(gè),那git將依次應(yīng)用到最新的提交后面,如下兩圖所示,圖四為初始狀態(tài),圖五為執(zhí)行rebase后的狀態(tài)。  



   簡(jiǎn)單來(lái)說(shuō),git rebase提取操作有點(diǎn)像git cherry-pick一樣,執(zhí)行rebase后依次將當(dāng)前的提交cherry-pick到目標(biāo)分支上,然后將在原始分支上的已提取的commit刪除。

merge OR rebase

那什么時(shí)候用merge,什么時(shí)候用rebase呢? 

再舉個(gè)例子: 

初始狀態(tài)如下圖六所示: 

         和之前一樣的是,develop分支也是在 (3.added merge.txt file)處從master分支拉取develop分支。不一樣的是兩個(gè)分支各個(gè)commit的時(shí)間不同,之前develop分支的4和5commit在master分支3之后6之前,現(xiàn)在是develop分支的4提交早于master分支的5提交,develop分支的6提交晚于master的5提交早于master的7提交。  


在上圖情況下,在master分支的7commit處,執(zhí)行g(shù)it merge develop,結(jié)果如下圖七所示: 


執(zhí)行g(shù)it rebase develop,結(jié)果如下圖八所示: 


1. 可以看出merge結(jié)果能夠體現(xiàn)出時(shí)間線,但是rebase會(huì)打亂時(shí)間線。 
2. 而rebase看起來(lái)簡(jiǎn)潔,但是merge看起來(lái)不太簡(jiǎn)潔。 
3. 最終結(jié)果是都把代碼合起來(lái)了,所以具體怎么使用這兩個(gè)命令看項(xiàng)目需要。

       還有一點(diǎn)說(shuō)明的是,在項(xiàng)目中經(jīng)常使用git pull來(lái)拉取代碼,git pull相當(dāng)于是git fetch + git merge,如果此時(shí)運(yùn)行g(shù)it pull -r,也就是git pull –rebase,相當(dāng)于git fetch + git rebase

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

到此這篇關(guān)于詳解git merge 與 git rebase的區(qū)別的文章就介紹到這了,更多相關(guān)git merge與git rebase內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • git merge最簡(jiǎn)潔用法詳解
  • 詳解git merge命令應(yīng)用的三種情景
  • 詳解git無(wú)法pull倉(cāng)庫(kù)refusing to merge unrelated histories
  • git merge --ff/--no-ff/--ff-only 三種選項(xiàng)參數(shù)的區(qū)別解析

標(biāo)簽:襄陽(yáng) 哈爾濱 雙鴨山 鄂爾多斯 遵義 莆田 丹東 錫林郭勒盟

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解git merge 與 git rebase的區(qū)別》,本文關(guān)鍵詞  詳解,git,merge,與,rebase,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解git merge 與 git rebase的區(qū)別》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于詳解git merge 與 git rebase的區(qū)別的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    望江县| 共和县| 勐海县| 法库县| 五寨县| 临邑县| 平度市| 盐亭县| 泾川县| 台中市| 江陵县| 东城区| 安吉县| 宽城| 固始县| 吴堡县| 广汉市| 洱源县| 屏东市| 五原县| 宿迁市| 连平县| 麻栗坡县| 漾濞| 玛多县| 延安市| 准格尔旗| 潜山县| 阳新县| 玛纳斯县| 绥滨县| 东明县| 武邑县| 富民县| 临清市| 淮阳县| 肃宁县| 青神县| 义乌市| 顺昌县| 什邡市|