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

Git rebase命令使用實戰(zhàn)

 更新時間:2020年07月24日 11:07:40   作者:胡峻崢  
這篇文章主要介紹了Git rebase命令使用實戰(zhàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、前言

  一句話,git rebase 可以幫助項目中的提交歷史干凈整潔!??!

二、避免合并出現(xiàn)分叉現(xiàn)象git merge操作

  1、新建一個 develop 分支

  

  2、在develop分支上新建兩個文件

  3、然后分別執(zhí)行 add、commit、push

  4、接著切換到master分支

  分別添加c.txt 和 d.txt兩個文件,分別進行add、commit、push

  5、現(xiàn)在想把develop分支上開發(fā)的部分合并到master分支上

  6、git merge 會將master和develop合并的過程通過如下形式展示出來。

  借助 gitk 命令

  借助sourceTree工具

git rebase操作

  如果master和develop分支上的這些開發(fā)部分都是同一個人操作,在合并的時候不想產(chǎn)生這種分叉的結(jié)果,怎么辦呢?

  git-rebase命令簡介:用在從上游分支獲取最新commit信息,并有機的將當(dāng)前分支和上游分支進行合并。因為develop分支是在master分支基礎(chǔ)上建立的,所以master稱為topic的上游分支。

  1、首先通過 git reset 恢復(fù)到master合并之前的狀態(tài)

  2、切換到develop分支,執(zhí)行如下操作

  3、如果你想把 rebase 之后的 master 分支推送到遠程倉庫,Git 會阻止你這么做,因為兩個分支包含沖突。但你可以傳入 –force 標(biāo)記來強行推送。

  4、查看一下develop分支合并的效果,如下。

  看一下rebase的結(jié)果,就像是develop先把自己的提交保存起來,然后將master中的提交合并過來,最后在加上自身分支的提交,這樣就不存在分支的合并效果了。

  5、接著切換到master分支,執(zhí)行g(shù)it merge 操作就可以了

  這時候,master和develop分支已經(jīng)同步了。

其他異常情況

  在rebase的過程中,也許會出現(xiàn)沖突(conflict). 在這種情況,Git會停止rebase并會讓你去解決 沖突;在解決完沖突后,用"git-add"命令去更新這些內(nèi)容的索引(index),然后你無需執(zhí)行 git-commit,只要執(zhí)行 git rebase --continue。這樣git會繼續(xù)應(yīng)用(apply)余下的補丁。在任何時候,你可以用--abort參數(shù)來終止rebase的行動,并且"mywork" 分支會回到rebase開始前的狀態(tài)。即git rebase --abort。

手動合并多個commit記錄

rebase -i 命令介紹

git rebase -i [startpoint] [endpoint]

  其中-i的意思是--interactive,即彈出交互式的界面讓用戶編輯完成合并操作,[startpoint] [endpoint]則指定了一個編輯區(qū)間,如果不指定[endpoint],則該區(qū)間的終點默認是當(dāng)前分支HEAD所指向的commit(注:該區(qū)間指定的是一個前開后閉的區(qū)間)。

在查看到了log日志后,我們運行以下命令:

git rebase -i 0bb85c 582db9

或者

git rebase -i HEAD~3
 

  上面未被注釋的部分列出的是我們本次rebase操作包含的所有提交,下面注釋部分是git為我們提供的命令說明。每一個commit id 前面的pick表示指令類型,git 為我們提供了以下幾個命令:

  pick:保留該commit(縮寫:p)
  reword:保留該commit,但我需要修改該commit的注釋(縮寫:r)
  edit:保留該commit, 但我要停下來修改該提交(不僅僅修改注釋)(縮寫:e)
  squash:將該commit和前一個commit合并(縮寫:s)
  fixup:將該commit和前一個commit合并,但我不要保留該提交的注釋信息(縮寫:f)
  exec:執(zhí)行shell命令(縮寫:x)
  drop:我要丟棄該commit(縮寫:d)

rebase -i命令執(zhí)行

  1、git rebase -i HEAD~3

  2、編輯合并信息

  3、修改commit信息

  4、commit信息預(yù)覽

  5、commit合并結(jié)果

  6、可以看到master上之后又1條提交記錄了,而develop上還有3個提交記錄

  還是要通過 git push -f 命令將合并的commit結(jié)果提交的遠程倉庫中。

  如果develop分支也想要變成master分支這種合并效果,記住不要使用git merge 命令,還時會出現(xiàn)分叉的情況。繼續(xù)使用 git rebase master命令。

自動合并多個commit記錄

命令介紹

  git commit –fixup 自動在commit消息前添加fixup!關(guān)鍵字。

  git rebase -i –autosquash 使用rebase自動合并被標(biāo)記為fixup!的commit,其實是根據(jù)sha值來的。

命令操作

  1.繼續(xù)修復(fù)如下圖所示對應(yīng)的bug

  2、修改完之后執(zhí)行 git commit --fixup 需要合并的commit id

  3、commit fixup 之后的效果

  4、執(zhí)行g(shù)it rebase -i --autosquash 需要合并commit id的父級commit id

    或者

git rebase -i --autosquash commit id^
   

  5、執(zhí)行rebaseautosquash結(jié)果

到此這篇關(guān)于Git rebase命令使用實戰(zhàn)的文章就介紹到這了,更多相關(guān)Git rebase命令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • git merge最簡潔用法詳解

    git merge最簡潔用法詳解

    git-merge 命令是用于從指定的 commit(s) 合并到當(dāng)前分支的操作,本文重點給大家介紹git merge最簡潔用法,感興趣的朋友跟隨小編一起看看吧
    2020-12-12
  • GitHub入門教程 手把手教你最簡單的開源項目托管

    GitHub入門教程 手把手教你最簡單的開源項目托管

    這篇文章主要介紹了GitHub入門教程 手把手教你最簡單的開源項目托管,需要的朋友可以參考下
    2016-12-12
  • 詳解秒殺系統(tǒng)設(shè)計的5個要點

    詳解秒殺系統(tǒng)設(shè)計的5個要點

    這篇文章主要為大家介紹了秒殺系統(tǒng)設(shè)計的5個要點詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • VSCode 安裝 Copilot 詳細過程和實例代碼(最新推薦)

    VSCode 安裝 Copilot 詳細過程和實例代碼(最新推薦)

    Copilot 作為一款 AI 輔助編程工具,可以極大地提高開發(fā)效率,讓編程變得更加輕松愉快,在實際開發(fā)過程中,我們要注意審查和測試生成的代碼,確保其符合項目需求和標(biāo)準(zhǔn),這篇文章主要介紹了VSCode 安裝 Copilot 詳細過程和實例,需要的朋友可以參考下
    2024-05-05
  • Hash算法示例應(yīng)用場景解延伸探究

    Hash算法示例應(yīng)用場景解延伸探究

    這篇文章主要為大家介紹了Hash算法示例應(yīng)用場景解延伸探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 常用VsCode 快捷鍵(Window & Mac)GIF演示

    常用VsCode 快捷鍵(Window & Mac)GIF演示

    本文給大家分享了23個常用VsCode 快捷鍵(Window & Mac)的GIF動圖演示,非常的實用,有需要的小伙伴可以拿走參考
    2020-02-02
  • volatile保證可見性及重排序方法

    volatile保證可見性及重排序方法

    這篇文章主要為大家介紹了volatile保證可見性及重排序方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Git 教程之查看提交歷史詳解

    Git 教程之查看提交歷史詳解

    本文主要介紹Git 查看提交歷史的知識,這里整理了詳細資料及命令用法,有興趣的小伙伴可以參考下
    2016-09-09
  • 12個Visual Studio調(diào)試效率技巧(小結(jié))

    12個Visual Studio調(diào)試效率技巧(小結(jié))

    這篇文章主要介紹了12個Visual Studio調(diào)試效率技巧,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2020-07-07
  • pytorch從頭開始搭建UNet++的過程詳解

    pytorch從頭開始搭建UNet++的過程詳解

    大家都知道Unet是一個最近比較火的網(wǎng)絡(luò)結(jié)構(gòu),這篇文章主要介紹了pytorch從頭開始搭建UNet++的過程詳解,需要的朋友可以參考下
    2022-11-11

最新評論