git?stash(儲藏)的用法總結
當在一個分支的開發(fā)工作未完成,卻又要切換到另外一個分支進行開發(fā)的時候,除了commit原分支的代碼改動的方法外,我覺得git stash是一個更加便捷的選擇。
git stash(git儲藏)可用于以下情形:
- 發(fā)現(xiàn)有一個類是多余的,想刪掉它又擔心以后需要查看它的代碼,想保存它但又不想增加一個臟的提交。這時就可以考慮git stash。
使用git的時候,我們往往使用分支(branch)解決任務切換問題,例如,我們往往會建一個自己的分支去修改和調(diào)試代碼, 如果別人或者自己發(fā)現(xiàn)原有的分支上有個不得不修改的bug,我們往往會把完成一半的代碼commit提交到本地倉庫,然后切換分支去修改bug,改好之后再切換回來。這樣的話往往log上會有大量不必要的記錄。其實如果我們不想提交完成一半或者不完善的代碼,但是卻不得不去修改一個緊急Bug,那么使用git stash就可以將你當前未提交到本地(和服務器)的代碼推入到Git的棧中,這時候你的工作區(qū)間和上一次提交的內(nèi)容是完全一樣的,所以你可以放心的修Bug,等到修完Bug,提交到服務器上后,再使用git stash apply將以前一半的工作應用回來。
- 經(jīng)常有這樣的事情發(fā)生,當你正在進行項目中某一部分的工作,里面的東西處于一個比較雜亂的狀態(tài),而你想轉(zhuǎn)到其他分支上進行一些工作。問題是,你不想提交進行了一半的工作,否則以后你無法回到這個工作點。解決這個問題的辦法就是git stash命令。儲藏(stash)可以獲取你工作目錄的中間狀態(tài)——也就是你修改過的被追蹤的文件和暫存的變更——并將它保存到一個未完結變更的堆棧中,隨時可以重新應用。
步驟如下:
- 添加改動到stash。在原分支 git stash save -a "messeag",網(wǎng)上很多很多資料都沒有加 -a 這個option選項,我想他們的代碼開發(fā)可能都是在原代碼上進行修改吧。而對于在項目里加入了代碼新文件的開發(fā)來說,-a選項才會將新加入的代碼文件同時放入暫存區(qū)。
恢復改動。如果你要恢復的是最近的一次改動,git stash pop 即可,我用這個用的最多。如果有多次stash操作,那就通過git stash list查看stash列表,從中選擇你想要pop的stash,運行命令git stash pop stash@{id}或者 git stash apply stash@{id}即可。這方面網(wǎng)上的資料挺多的。
刪除stash。git stash drop <stash@{id}> 如果不加stash編號,默認的就是刪除最新的,也就是編號為0的那個,加編號就是刪除指定編號的stash。git stash clear 是清除所有stash,整個世界一下子清凈了!
git stash pop 與 git stash apply <stash@{id}> 的區(qū)別。
當我使用git stash pop 和 git stash apply 幾次以后,我發(fā)現(xiàn)stash list 好像比我預計的多了幾個stash。于是我便上網(wǎng)去了解了一下這兩個命令的區(qū)別。原來git stash pop stash@{id}命令會在執(zhí)行后將對應的stash id 從stash list里刪除,而 git stash apply stash@{id} 命令則會繼續(xù)保存stash id。對于有點強迫癥的我來說,是容不下越來越多的陳舊stash id 仍然存在的,所以我更習慣于用git stash pop 命令。
git stash 使用實例 :
生成測試環(huán)境
// 初始化倉庫,進行一次提交 # git init stash-test # cd stash-test && echo 'hello'> readme # git add . && git commit -m "init" // 修改工作區(qū)和暫存區(qū) # echo 'need to be stashed' >> readme # git add readme // 查看此時工作區(qū)和版本庫區(qū)別 # git diff HEAD diff --git a/readme b/readme index ce01362..55d6c28 100644 --- a/readme +++ b/readme @@ -1 +1,2 @@ hello +need to be stashed
執(zhí)行stash及恢復
// 暫存當前狀態(tài) # git stash // 查看當前工作區(qū)和版本庫區(qū)別 # git diff HEAD ==> 此時什么都沒有輸出,說明工作區(qū)被重置為HEAD指向內(nèi)容了 // 顯示已暫存列表 # git stash list stash@{0}: WIP on master: 440e976 init // 恢復暫存區(qū)和工作區(qū)進度 # git stash pop --index stash@{0} // 查看工作區(qū)和版本庫區(qū)別 # git diff HEAD diff --git a/readme b/readme index ce01362..55d6c28 100644 --- a/readme +++ b/readme @@ -1 +1,2 @@ hello
命令詳解:
git stash 對當前的暫存區(qū)和工作區(qū)狀態(tài)進行保存。 git stash list 列出所有保存的進度列表。 git stash pop [--index] [<stash>] 恢復工作進度
到此這篇關于git stash(儲藏)的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Web開發(fā)/設計人員應當知道的15個網(wǎng)站
建個好網(wǎng)站絕非易事,工欲善其事必先利其器。本文編譯了15個極其有用的網(wǎng)站,任何一位網(wǎng)站開發(fā)者或設計人員都應該收藏起來2011-05-05vs2019生成dll并調(diào)用的實現(xiàn)示例
這篇文章主要介紹了vs2019生成dll并調(diào)用的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02