Git分支管理—Bug分支

應(yīng)用場(chǎng)景:
當(dāng)你接到一個(gè)修復(fù)代號(hào)101的bug的任務(wù)時(shí),很自然地,你想創(chuàng)建一個(gè)分支issue-101來(lái)修復(fù)它,但是,等等,當(dāng)前正在dev上進(jìn)行的工作還沒(méi)有提交。并不是你不想提交,而是工作只進(jìn)行到一半,還沒(méi)法提交,預(yù)計(jì)完成還需1天時(shí)間。但是,必須在兩個(gè)小時(shí)內(nèi)修復(fù)該bug,怎么辦?

實(shí)戰(zhàn)

幸好,Git還提供了一個(gè)stash功能,可以把當(dāng)前工作現(xiàn)場(chǎng)“儲(chǔ)藏”起來(lái),等以后恢復(fù)現(xiàn)場(chǎng)后繼續(xù)工作:

$ git stash
Saved working directory and index state WIP on dev: 6224937 add merge
HEAD is now at 6224937 add merge```
現(xiàn)在,用`git status`查看工作區(qū),就是干凈的(除非有沒(méi)有被Git管理的文件),因此可以放心地創(chuàng)建分支來(lái)修復(fù)bug。

首先確定要在哪個(gè)分支上修復(fù)bug,假定需要在`master`分支上修復(fù),就從`master`創(chuàng)建臨時(shí)分支:

$ git checkout master
Switched to branch 'master'
Your branch is ahead of 'origin/master' by 6 commits.
$ git checkout -b issue-101
Switched to a new branch 'issue-101'```
現(xiàn)在修復(fù)bug,需要把Git is free software ...改為Git is a free software ...,然后提交:

$ git add readme.txt 
$ git commit -m "fix bug 101"
[issue-101 cc17032] fix bug 101
 1 file changed, 1 insertion(+), 1 deletion(-)```
修復(fù)完成后,切換到master分支,并完成合并,最后刪除issue-101分支:

$ git checkout master
Switched to branch 'master'
Your branch is ahead of 'origin/master' by 2 commits.
$ git merge --no-ff -m "merged bug fix 101" issue-101
Merge made by the 'recursive' strategy.
readme.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
$ git branch -d issue-101
Deleted branch issue-101 (was cc17032).```

現(xiàn)在,是時(shí)候接著回到dev分支干活了!

$ git checkout dev
Switched to branch 'dev'
$ git status
# On branch dev
nothing to commit (working directory clean)```

工作區(qū)是干凈的,剛才的工作現(xiàn)場(chǎng)存到哪去了?用git stash list命令看看:

$ git stash list
stash@{0}: WIP on dev: 6224937 add merge```
工作現(xiàn)場(chǎng)還在,Git把stash內(nèi)容存在某個(gè)地方了,但是需要恢復(fù)一下,有兩個(gè)辦法:

  • git stash apply恢復(fù),但是恢復(fù)后,stash內(nèi)容并不刪除,你需要用git stash drop來(lái)刪除;

  • git stash pop,恢復(fù)的同時(shí)把stash內(nèi)容也刪了.

$ git stash pop
# On branch dev
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#       new file:   hello.py
#
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#       modified:   readme.txt
#
Dropped refs/stash@{0} (f624f8e5f082f2df2bed8a4e09c12fd2943bdd40)```
再用git stash list查看,就看不到任何stash內(nèi)容了:

$ git stash list```
你可以多次stash,恢復(fù)的時(shí)候,先用git stash list查看,然后恢復(fù)指定的stash,用命令:

$ git stash apply stash@{0}```
***
######*小結(jié)

修復(fù)bug時(shí),我們會(huì)通過(guò)創(chuàng)建新的bug分支進(jìn)行修復(fù),然后合并,最后刪除;

當(dāng)手頭工作沒(méi)有完成時(shí),先把工作現(xiàn)場(chǎng)`git stash`一下,然后去修復(fù)bug,修復(fù)后,再`git stash pop`,回到工作現(xiàn)場(chǎng)。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. 安裝 Github 查看是否安裝git: $ git config --global user.name "...
    Albert_Sun閱讀 13,852評(píng)論 9 163
  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git,從https:/...
    落魂灬閱讀 12,839評(píng)論 4 54
  • Git是目前最流行的版本管理系統(tǒng),也是最先進(jìn)的分布式版本控制系統(tǒng)(distributed version cont...
    pro648閱讀 5,982評(píng)論 1 17
  • 如果生活給了你太多委屈 請(qǐng)到我這里來(lái) 我借你肩膀依靠 我會(huì)是你心兒棲息的港灣 即是命運(yùn)把你捉弄 請(qǐng)不要介懷 請(qǐng)到我...
    歸夢(mèng)何期閱讀 294評(píng)論 2 1
  • 早起 運(yùn)動(dòng) 晨間日記,作業(yè)內(nèi)容,喝水打卡,洗衣服,去西西弗看書(shū),看電影 生活入賬,午餐6元 未練字
    w尺素寸心閱讀 235評(píng)論 0 0

友情鏈接更多精彩內(nèi)容