溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用git stash暫存

發(fā)布時間:2020-07-23 13:57:22 來源:億速云 閱讀:282 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了如何使用git stash暫存,內(nèi)容簡而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

為什么我們需要它

不得不說,在知道這個命令的時,以及之后的使用中,我都超級熱愛這個命令,因為它真的太好用了。

給大家說一下我使用這個命令的場景:

此時我在 feature_666 分支,非常聚精會神加持高專注地實現(xiàn)一個功能 666 模塊,簡直鍵盤如飛的編寫代碼~~~
然后這時,客戶反饋出一個 bug , 非常嚴(yán)重,必須立馬解決,優(yōu)先級為 0 ?。?!
于是,我需要去到 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)前暫存的記錄

#查看記錄
git stash list

修改存儲到什么位置了?

當(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 存儲的修改起個名字,顯然非常重要,方式如下:

git stash save <message>

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暫存的內(nèi)容,如果你們有學(xué)習(xí)到知識或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI