日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 综合教程 >内容正文

综合教程

git rebase和merge区别及使用场景

發(fā)布時(shí)間:2023/11/22 综合教程 53 生活家
生活随笔 收集整理的這篇文章主要介紹了 git rebase和merge区别及使用场景 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

什么是 rebase?

git rebase 你其實(shí)可以把它理解成是“重新設(shè)置基線”,將你的當(dāng)前分支重新設(shè)置開始點(diǎn)。這個(gè)時(shí)候才能知道你當(dāng)前分支于你需要比較的分支之間的差異。
原理很簡(jiǎn)單:rebase需要基于一個(gè)分支來設(shè)置你當(dāng)前的分支的基線,這基線就是當(dāng)前分支的開始時(shí)間軸向后移動(dòng)到最新的跟蹤分支的最后面,這樣你的當(dāng)前分支就是最新的跟蹤分支。這里的操作是基于文件事務(wù)處理的,所以你不用怕中間失敗會(huì)影響文件的一致性。在中間的過程中你可以隨時(shí)取消rebase 事務(wù)。

官方解釋: https://git-scm.com/book/zh/v2/Git-分支-變基

git rebase 和 git merge 有啥區(qū)別?

rebase會(huì)把你當(dāng)前分支的 commit 放到公共分支的最后面,所以叫變基。就好像你從公共分支又重新拉出來這個(gè)分支一樣。
舉例:如果你從 master 拉了個(gè)feature分支出來,然后你提交了幾個(gè) commit,這個(gè)時(shí)候剛好有人把他開發(fā)的東西合并到 master 了,這個(gè)時(shí)候 master 就比你拉分支的時(shí)候多了幾個(gè) commit,如果這個(gè)時(shí)候你 rebase master 的話,就會(huì)把你當(dāng)前的幾個(gè) commit,放到那個(gè)人 commit 的后面。

rebase

merge 會(huì)把公共分支和你當(dāng)前的commit 合并在一起,形成一個(gè)新的 commit 提交

merge
注意:
  • 不要在公共分支使用rebase
  • 本地和遠(yuǎn)端對(duì)應(yīng)同一條分支,優(yōu)先使用rebase,而不是merge
拋出問題:

為什么不要再公共分支使用rebase?
因?yàn)橥蠓诺倪@些 commit 都是新的,這樣其他從這個(gè)公共分支拉出去的人,都需要再 rebase,相當(dāng)于你 rebase 東西進(jìn)來,就都是新的 commit 了

  • 1-2-3 是現(xiàn)在的分支狀態(tài)
  • 這個(gè)時(shí)候從原來的master ,checkout出來一個(gè)prod分支
  • 然后master提交了4.5,prod提交了6.7
  • 這個(gè)時(shí)候master分支狀態(tài)就是1-2-3-4-5,prod狀態(tài)變成1-2-3-6-7
  • 如果在prod上用rebase master ,prod分支狀態(tài)就成了1-2-3-4-5-6-7
  • 如果是merge
    1-2-3-6-7-8
    ........ |4-5|
  • 會(huì)出來一個(gè)8,這個(gè)8的提交就是把4-5合進(jìn)來的提交

merge和rebase實(shí)際上只是用的場(chǎng)景不一樣
更通俗的解釋一波.
比如rebase,你自己開發(fā)分支一直在做,然后某一天,你想把主線的修改合到你的分支上,做一次集成,這種情況就用rebase比較好.把你的提交都放在主線修改的頭上
如果用merge,腦袋上頂著一筆merge的8,你如果想回退你分支上的某個(gè)提交就很麻煩,還有一個(gè)重要的問題,rebase的話,本來我的分支是從3拉出來的,rebase完了之后,就不知道我當(dāng)時(shí)是從哪兒拉出來的我的開發(fā)分支
同樣的,如果你在主分支上用rebase, rebase其他分支的修改,是不是要是別人想看主分支上有什么歷史,他看到的就不是完整的歷史課,這個(gè)歷史已經(jīng)被你篡改了

常用指令

  • git rebase -I dev 可以將dev分支合并到當(dāng)前分支
    這里的”-i“是指交互模式。就是說你可以干預(yù)rebase這個(gè)事務(wù)的過程,包括設(shè)置commit message,暫停commit等等。
  • git rebase –abort 放棄一次合并
  • 合并多次commit操作:
    1 git rebase -i dev
    2 修改最后幾次commit記錄中的pick 為squash
    3 保存退出,彈出修改文件,修改commit記錄再次保存退出(刪除多余的change-id 只保留一個(gè))
    4 git add .
    5 git rebase --continue

總結(jié)

以上是生活随笔為你收集整理的git rebase和merge区别及使用场景的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。