目錄
一、提交節點圖解
二、實際git提交範例
三、推薦使用場景
首頁 開發工具 Git git學習之rebase實例詳解

git學習之rebase實例詳解

Mar 22, 2022 pm 06:22 PM
git

本篇文章為大家帶來了關於Git的相關知識,其中主要介紹了rebase的相關問題,rebase,變基,可以直接理解為改變基底。 feature分支是基於master分支的B拉出來的分支,feature的基底是B,希望對大家有幫助。

git學習之rebase實例詳解

推薦學習:《Git學習教學

本文用最簡潔的範例讓你快速掌握rebase原理與用法

一、提交節點圖解

首先透過簡單的提交節點圖解感受一下rebase在做什麼

兩個分支master和feature,其中feature是在提交點B處從master上拉出的分支

master上有一個新提交M,feature上有兩個新提交C和D
git學習之rebase實例詳解
此時切換到feature分支上,執行如下指令,相當於想要把master分支合併到feature分支(這一步的場景就可以類比為我們在自己的分支feature上開發了一段時間了,準備從主幹master上拉一下最新改動)

git checkout featuregit rebase master

//这两条命令等价于git rebase master feature
登入後複製

下圖為變基後的提交節點圖,說明其工作原理:
git學習之rebase實例詳解

  • feature:待變基分支、目前分支
  • master:基分支、目標分支

官方解釋(如果覺得看不懂可以直接看下一段):當執行rebase操作時,git會從兩個分支的共同祖先開始提取待變基分支上的修改,然後將待變基分支指向基分支的最新提交,最後將剛才提取的修改應用到基分支的最新提交的後面。

結合範例解釋:當在feature分支上執行git rebase master時,git會從master和featuer的共同祖先B開始提取feature分支上的修改,也就是C和D兩個提交,先提取到。然後將feature分支指向master分支的最新提交上,也就是M。最後把提取的C和D接到M後面,但這個過程是刪除原來的C和D,生成新的C’和D’,他們的提交內容一樣,但commit id不同。 feature自然最後也是指向D’。

通俗解釋(重要!!):rebase,變基,可以直接理解為改變基底。 feature分支是基於master分支的B被拉出來的分支,feature的基底是B。而master在B之後有新的提交,就等於此時要用master上新的提交來作為feature分支的新基底。實際操作為把B之後feature的提交存下來,然後刪除原來這些提交,再找到master的最新提交位置,把存下來的提交再接上去(新節點新commit id),如此feature分支的基底就相當於是變成了M而不是原來的B了。 (注意,如果master上在B以後沒有新提交,那麼就還是用原來的B作為基,rebase操作相當於無效,此時和git merge就基本沒區別了,差異只在於git merge會多一條記錄Merge操作的提交記錄)

上面的範例可抽象化為如下實際工作場景:張三從B拉了程式碼進行開發,目前提交了兩次,開發到D了;李四也從B拉出來開發了並且開發完畢,他提交到了M,然後合到主幹上了。此時張三想拉下最新程式碼,於是他在feature分支上執行了git rebase master,即把master分支給rebase過來,由於李四更早開發完並合了主幹,如此就相當於張三是基於李四的最新提交M進行的開發了。


二、實際git提交範例

依照上面的圖解構造了提交記錄,如下圖所示:(ABM是master分支線,ABCD是feature分支線。這裡畫成了master變色分叉出來,這不影響理解,知道是表示兩個分支兩條線即可!)
git學習之rebase實例詳解
此時,在feature分支上執行git rebase master

變基完成以後,ABCD是原來的feature分支線,ABMC'D'是新的feature分支線,ABM是master分支線(沒有變化)
git學習之rebase實例詳解


三、推薦使用場景

搞來搞去那麼多,這其實是最重要的。不同公司,不同情況有不同使用場景,不過大部分情況推薦如下:

  1. 拉公共分支最新程式碼的時候使用rebase,也就是git pull -r或git pull --rebase,但有個缺點就是rebase以後我就不知道我目前的分支最早是從哪個分支拉出來的了,因為基底變了嘛。 (正因如此,大部分公司其實都不會用rebase,基本上統一使用merge,雖然會多出無意義的一條提交記錄“Merge … to …”,但至少能知道誰做了什麼事)
  2. 往公共分支上合程式碼的時候,使用merge。 (如果使用rebase,那麼其他開發人員想看主分支的歷史,就不是原來的歷史了,歷史已經被你篡改了。比如張三和李四從共同的節點拉出來開發,張三先開發完提交了兩次然後merge上去了,李四後來開發完rebase上去(注意李四需要切換到主分支,然後執行git rebase,然後再git pull到遠端),則李四的新提交變成了張三的新提交的新基底,本來李四的提交是最新的,結果最新的提交顯示反而是張三的,就亂套了)

推薦學習:《Git教程

以上是git學習之rebase實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

git怎麼更新代碼 git怎麼更新代碼 Apr 17, 2025 pm 04:45 PM

更新 git 代碼的步驟:檢出代碼:git clone https://github.com/username/repo.git獲取最新更改:git fetch合併更改:git merge origin/master推送更改(可選):git push origin master

git怎麼下載項目到本地 git怎麼下載項目到本地 Apr 17, 2025 pm 04:36 PM

要通過 Git 下載項目到本地,請按以下步驟操作:安裝 Git。導航到項目目錄。使用以下命令克隆遠程存儲庫:git clone https://github.com/username/repository-name.git

git怎麼合併代碼 git怎麼合併代碼 Apr 17, 2025 pm 04:39 PM

Git 代碼合併過程:拉取最新更改以避免衝突。切換到要合併的分支。發起合併,指定要合併的分支。解決合併衝突(如有)。暫存和提交合併,提供提交消息。

git commit怎麼用 git commit怎麼用 Apr 17, 2025 pm 03:57 PM

Git Commit 是一種命令,將文件變更記錄到 Git 存儲庫中,以保存項目當前狀態的快照。使用方法如下:添加變更到暫存區域編寫簡潔且信息豐富的提交消息保存並退出提交消息以完成提交可選:為提交添加簽名使用 git log 查看提交內容

git下載不動怎麼辦 git下載不動怎麼辦 Apr 17, 2025 pm 04:54 PM

解決 Git 下載速度慢時可採取以下步驟:檢查網絡連接,嘗試切換連接方式。優化 Git 配置:增加 POST 緩衝區大小(git config --global http.postBuffer 524288000)、降低低速限制(git config --global http.lowSpeedLimit 1000)。使用 Git 代理(如 git-proxy 或 git-lfs-proxy)。嘗試使用不同的 Git 客戶端(如 Sourcetree 或 Github Desktop)。檢查防火

git怎麼更新本地代碼 git怎麼更新本地代碼 Apr 17, 2025 pm 04:48 PM

如何更新本地 Git 代碼?用 git fetch 從遠程倉庫拉取最新更改。用 git merge origin/<遠程分支名稱> 將遠程變更合併到本地分支。解決因合併產生的衝突。用 git commit -m "Merge branch <遠程分支名稱>" 提交合併更改,應用更新。

如何解決PHP項目中的高效搜索問題? Typesense助你實現! 如何解決PHP項目中的高效搜索問題? Typesense助你實現! Apr 17, 2025 pm 08:15 PM

在開發一個電商網站時,我遇到了一個棘手的問題:如何在大量商品數據中實現高效的搜索功能?傳統的數據庫搜索效率低下,用戶體驗不佳。經過一番研究,我發現了Typesense這個搜索引擎,並通過其官方PHP客戶端typesense/typesense-php解決了這個問題,大大提升了搜索性能。

git怎麼刪除倉庫 git怎麼刪除倉庫 Apr 17, 2025 pm 04:03 PM

要刪除 Git 倉庫,請執行以下步驟:確認要刪除的倉庫。本地刪除倉庫:使用 rm -rf 命令刪除其文件夾。遠程刪除倉庫:導航到倉庫設置,找到“刪除倉庫”選項,確認操作。

See all articles