欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年07月31日 09:57:46   作者:zzhongcy  
這篇文章主要介紹了詳解git merge 與 git rebase的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

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

merge與rebase的區(qū)別

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


merge

        假設現在HEAD在(6.added hello.txt file)處,也就是在master分支最近的一次提交處,此時執(zhí)行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是這么工作的呢? 

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


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

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



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

merge OR rebase

那什么時候用merge,什么時候用rebase呢? 

再舉個例子: 

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

         和之前一樣的是,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處,執(zhí)行git merge develop,結果如下圖七所示: 


執(zhí)行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 merge 與 git rebase的區(qū)別的文章就介紹到這了,更多相關git merge與git rebase內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Git命令常用操作之代碼拉取和提交方式

    Git命令常用操作之代碼拉取和提交方式

    這篇文章主要介紹了Git命令常用操作之代碼拉取和提交方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • wireshark捕獲過濾器語法使用解析

    wireshark捕獲過濾器語法使用解析

    這篇文章主要為大家介紹了wireshark捕獲過濾器語法使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • 一個批量編碼轉換及ASP/JS加解密/簡繁轉換的工具

    一個批量編碼轉換及ASP/JS加解密/簡繁轉換的工具

    一個批量編碼轉換及ASP/JS加解密/簡繁轉換的工具...
    2007-05-05
  • VS2019 安裝時閃退的解決方法

    VS2019 安裝時閃退的解決方法

    這篇文章主要介紹了VS2019 安裝時閃退的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • adb shell input keyevent 控制按鍵輸入的數值(收藏版)

    adb shell input keyevent 控制按鍵輸入的數值(收藏版)

    adb shell的功能很強大,可以使用很多功能,今天我們說下通過控制按鍵輸入,需要的朋友可以參考下
    2019-10-10
  • VSCode如何遠程連接Linux教程(密鑰的使用)

    VSCode如何遠程連接Linux教程(密鑰的使用)

    本文主要介紹了VSCode如何遠程連接Linux教程,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • JSON數據格式化方法詳細介紹

    JSON數據格式化方法詳細介紹

    JSON(JavaScript?Object?Notation)是一種輕量級的數據交換格式,基于JavaScript編程語言的一個子集,它已經成為一個完全獨立于語言的文本格式,被廣泛采用和應用于多種編程境中,需要的朋友可以參考下
    2024-09-09
  • vscode擴展代碼定位實現步驟詳解

    vscode擴展代碼定位實現步驟詳解

    這篇文章主要為大家介紹了vscode擴展代碼定位實現步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • chatGPT使用及注冊過程中常見的一些錯誤解決方法(所有報錯匯總)

    chatGPT使用及注冊過程中常見的一些錯誤解決方法(所有報錯匯總)

    這篇文章主要介紹了chatGPT注冊報錯及使用過程中報錯匯總及解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • Git命令的簡單整理大全

    Git命令的簡單整理大全

    這篇文章主要給大家介紹了關于Git命令的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-02-02

最新評論