面試官:說說你對Git Stash 的理解?應(yīng)用場景?
本文轉(zhuǎn)載自微信公眾號「JS每日一題」,作者 灰灰。轉(zhuǎn)載本文請聯(lián)系JS每日一題公眾號。
一、是什么
stash,譯為存放,在 git 中,可以理解為保存當(dāng)前工作進(jìn)度,會把暫存區(qū)和工作區(qū)的改動(dòng)進(jìn)行保存,這些修改會保存在一個(gè)棧上
后續(xù)你可以在任何時(shí)候任何分支重新將某次的修改推出來,重新應(yīng)用這些更改的代碼
默認(rèn)情況下,git stash會緩存下列狀態(tài)的文件:
- 添加到暫存區(qū)的修改(staged changes)
- Git跟蹤的但并未添加到暫存區(qū)的修改(unstaged changes)
但以下狀態(tài)的文件不會緩存:
- 在工作目錄中新的文件(untracked files)
- 被忽略的文件(ignored files)
如果想要上述的文件都被緩存,可以使用-u或者--include-untracked可以工作目錄新的文件,使用-a或者--all命令可以當(dāng)前目錄下的所有修改
二、如何使用
關(guān)于git stash常見的命令如下:
- git stash
- git stash save
- git stash list
- git stash pop
- git stash apply
- git stash show
- git stash drop
- git stash clear
- git stash
保存當(dāng)前工作進(jìn)度,會把暫存區(qū)和工作區(qū)的改動(dòng)保存起來
git stash save
git stash save可以用于存儲修改.并且將git的工作狀態(tài)切回到HEAD也就是上一次合法提交上
如果給定具體的文件路徑,git stash只會處理路徑下的文件.其他的文件不會被存儲,其存在一些參數(shù):
--keep-index 或者 -k 只會存儲為加入 git 管理的文件
--include-untracked 為追蹤的文件也會被緩存,當(dāng)前的工作空間會被恢復(fù)為完全清空的狀態(tài)
-a 或者 --all 命令可以當(dāng)前目錄下的所有修改,包括被 git 忽略的文件
git stash list
顯示保存進(jìn)度的列表。也就意味著,git stash命令可以多次執(zhí)行,當(dāng)多次使用git stash命令后,棧里會充滿未提交的代碼,如下:
其中,stash@{0}、stash@{1}就是當(dāng)前stash的名稱
git stash pop
git stash pop 從棧中讀取最近一次保存的內(nèi)容,也就是棧頂?shù)膕tash會恢復(fù)到工作區(qū)
也可以通過 git stash pop + stash名字執(zhí)行恢復(fù)哪個(gè)stash恢復(fù)到當(dāng)前目錄
如果從stash中恢復(fù)的內(nèi)容和當(dāng)前目錄中的內(nèi)容發(fā)生了沖突,則需要手動(dòng)修復(fù)沖突或者創(chuàng)建新的分支來解決沖突
git stash apply
將堆棧中的內(nèi)容應(yīng)用到當(dāng)前目錄,不同于git stash pop,該命令不會將內(nèi)容從堆棧中刪除
也就說該命令能夠?qū)⒍褩5膬?nèi)容多次應(yīng)用到工作目錄中,適應(yīng)于多個(gè)分支的情況
同樣,可以通過git stash apply + stash名字執(zhí)行恢復(fù)哪個(gè)stash恢復(fù)到當(dāng)前目錄
git stash show
查看堆棧中最新保存的stash和當(dāng)前目錄的差異
通過使用git stash show -p查看詳細(xì)的不同
通過使用git stash show stash@{1}查看指定的stash和當(dāng)前目錄差異
git stash drop
git stash drop + stash名稱表示從堆棧中移除某個(gè)指定的stash
git stash clear
刪除所有存儲的進(jìn)度
三、應(yīng)用場景
當(dāng)你在項(xiàng)目的一部分上已經(jīng)工作一段時(shí)間后,所有東西都進(jìn)入了混亂的狀態(tài), 而這時(shí)你想要切換到另一個(gè)分支或者拉下遠(yuǎn)端的代碼去做一點(diǎn)別的事情
但是你創(chuàng)建一次未完成的代碼的commit提交,這時(shí)候就可以使用git stash
例如以下場景:
當(dāng)你的開發(fā)進(jìn)行到一半,但是代碼還不想進(jìn)行提交 ,然后需要同步去關(guān)聯(lián)遠(yuǎn)端代碼時(shí).如果你本地的代碼和遠(yuǎn)端代碼沒有沖突時(shí),可以直接通過git pull解決
但是如果可能發(fā)生沖突怎么辦.直接git pull會拒絕覆蓋當(dāng)前的修改,這時(shí)候就可以依次使用下述的命令:
- git stash
- git pull
- git stash pop
或者當(dāng)你開發(fā)到一半,現(xiàn)在要修改別的分支問題的時(shí)候,你也可以使用git stash緩存當(dāng)前區(qū)域的代碼
- git stash:保存開發(fā)到一半的代碼
- git commit -m '修改問題'
- git stash pop:將代碼追加到最新的提交之后