為什么我們需要它
不得不說,在知道這個命令的時,以及之后的使用中,我都超級熱愛這個命令,因為它真的太好用了。
給大家說一下我使用這個命令的場景:
此時我在 feature_666 分支,非常聚精會神加持高專注地實現(xiàn)一個功能 666 模塊,簡直鍵盤如飛的編寫代碼~~~
然后這時,客戶反饋出一個 bug , 非常嚴(yán)重,必須立馬解決,優(yōu)先級為 0 ?。。?br />
于是,我需要去到 release 分支去 checkout 新的分支去工作了,但是 666 功能還沒完成怎么辦?
此時我面臨著一個選擇題:
A:提交后切換,代碼保存到分支 feature_666,卻產(chǎn)生一個無意義的提交
B:不提交直接切換,然而這個選項根本沒人會選。
是不是很難選,此時,別忘記還有 C 選項!
C:使用 git stash , 將當(dāng)前修改(未提交的代碼)存入緩存區(qū),切換分支修改 bug ,回來再通過 git stash pop 取出來。
1. 暫存操作
#查看當(dāng)前狀態(tài)
git status
#如果有修改,添加修改文件
git add .
#暫存操作
git stash save '本次暫存的標(biāo)識名字'
2. 查看當(dāng)前暫存的記錄
修改存儲到什么位置了?
當(dāng)我們使用 git init給項目添加版本控制的時候,會在項目路徑下生成一個 .git 隱藏文件夾。.git 中存儲著版本管理的所有信息。
.git/refs/stash 中,存儲的是最后一個 stash 對應(yīng)的節(jié)點指針
同樣,在 .git/log/refs/stash 中可以看到我們?nèi)康?stash 記錄信息
存儲多個 stash 的情況
ok ,我們來嘗試一下修改文件,然后再次使用 git stash ,此時我們有個兩個 暫存修改,那么怎么查看呢?
git stash list //查看暫存區(qū)的所有暫存修改記錄
如果在未提交的情況下,執(zhí)行 git stash 兩次,無法準(zhǔn)確分辨兩個stash 具體修改的是哪些內(nèi)容,這樣用,顯的偉大的 Git 一點都不智能,怎么可以!。
所以,在這種情況下,給 stash 存儲的修改起個名字,顯然非常重要,方式如下:
3. 恢復(fù)暫存的工作
‘pop命令恢復(fù),恢復(fù)后,暫存區(qū)域會刪除當(dāng)前的記錄'
#恢復(fù)指定的暫存工作, 暫存記錄保存在list內(nèi),需要通過list索引index取出恢復(fù)
git stash pop stash@{index}
‘a(chǎn)pply命令恢復(fù),恢復(fù)后,暫存區(qū)域會保留當(dāng)前的記錄'
#恢復(fù)指定的暫存工作, 暫存記錄保存在list內(nèi),需要通過list索引index取出恢復(fù)
git stash apply stash@{index}
4. 刪除暫存
#刪除某個暫存, 暫存記錄保存在list內(nèi),需要通過list索引index取出恢復(fù)
git stash drop stash@{index}
#刪除全部暫存
git stash clear
到此這篇關(guān)于git stash暫存的操作方法的文章就介紹到這了,更多相關(guān)git stash暫存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- git的遠(yuǎn)程分支的作用和本地分支有什么區(qū)別
- 詳解git使用小結(jié)(本地分支與遠(yuǎn)程分支、git命令)
- Git獲取本地分支對應(yīng)的遠(yuǎn)端服務(wù)器分支名的方法
- 詳解idea中Git的Stash Changes和UnStash Changes用法
- git本地分支和stash內(nèi)容報錯消失的問題