63.Git Reset 詳解版本回滾的三種模式

git reset

意思就是可以讓HEAD這個(gè)指針指向其他版本。說白了就是通過此命令在版本之間進(jìn)行穿梭。
它有三種模式,soft,mixed,hard,具體的使用方法下面這張圖,展示的很全面了。

git各個(gè)區(qū)域和命令關(guān)系

這三個(gè)模式理解了,對于使用這個(gè)命令很有幫助。在理解這三個(gè)模式之前,需要略微知道一點(diǎn)Git的基本流程。正如上圖,Git會有三個(gè)區(qū)域:

Working Tree 當(dāng)前的工作區(qū)域
Index/Stage 暫存區(qū)域,和git stash命令暫存的地方不一樣。使用git add xx,就可以將xx添加近Stage里面
Repository 提交的歷史,即使用git commit提交后的結(jié)果

1. git reset --hard

首先,Git必須知道當(dāng)前版本是哪個(gè)版本,在Git中,用HEAD表示當(dāng)前版本,上一個(gè)版本就是HEAD^,上上一個(gè)版本就是HEAD^^,以此類推,當(dāng)然往上100個(gè)版本寫100個(gè)^比較容易數(shù)不過來,所以寫成HEAD~100。

--hard 會在重置 HEAD 和branch的同時(shí),重置緩存區(qū)和工作目錄里的內(nèi)容。當(dāng)你在 reset 后面加了--hard 參數(shù)時(shí),你的緩存區(qū)和工作目錄里的內(nèi)容會被完全重置為和HEAD的新位置相同的內(nèi)容。換句話說,就是你的沒有commit的修改會被全部擦掉。

回退到上一版本:

git reset --hard HEAD^

回退到指定版本號(以1a2b3c為例)的版本:

git reset --hard 1a2b3c

reset --hard:重置stage區(qū)和工作目錄:

2. git reset --soft

--soft 則會保留工作目錄的內(nèi)容,并把因?yàn)橹刂?HEAD 所帶來的新的文件差異放進(jìn)暫存區(qū)。

什么是「重置 HEAD 所帶來的新的差異」?就是這里:

--soft所帶來的新的差異

由于 HEAD 從 4 移動(dòng)到了 3,而且在 reset 的過程中工作目錄和暫存區(qū)的內(nèi)容沒有被清理掉,所以 4 中的改動(dòng)在 reset 后就也成了工作目錄新增的「工作目錄和 HEAD 的差異」。這就是上面一段中所說的「重置 HEAD 所帶來的差異」。

這就是--soft 和 --hard 的區(qū)別:--hard 會清空工作目錄和暫存區(qū)的改動(dòng),*而 --soft則會保留工作目錄的內(nèi)容,并把因?yàn)楸A艄ぷ髂夸泝?nèi)容所帶來的新的文件差異放進(jìn)暫存區(qū)。

3.git reset 不帶參數(shù)或帶--mixed

git reset 如果不加參數(shù),那么默認(rèn)使用 --mixed 參數(shù)。此時(shí)表示要:保留工作目錄,并清空暫存區(qū)。也就是說,工作目錄的修改、暫存區(qū)的內(nèi)容以及由 reset 所導(dǎo)致的新的文件差異,都會被放進(jìn)工作目錄。簡而言之,就是「把所有差異都混合(mixed)放在工作目錄中」。

總結(jié)

首先,Git必須知道當(dāng)前版本是哪個(gè)版本,在Git中,用HEAD表示當(dāng)前版本,上一個(gè)版本就是HEAD^,上上一個(gè)版本就是HEAD^^,以此類推,當(dāng)然往上100個(gè)版本寫100個(gè)^比較容易數(shù)不過來,所以寫成HEAD~100。

回退到上一版本:

git reset --hard HEAD^

回退到指定版本號(以1a2b3c為例)的版本:

git reset --hard 1a2b3c

--hard 會清空工作目錄和暫存區(qū)的改動(dòng),
--soft則會保留工作目錄的內(nèi)容,并把因?yàn)楸A艄ぷ髂夸泝?nèi)容所帶來的新的文件差異放進(jìn)暫存區(qū)。
--mixed 參數(shù)。git reset 如果不加參數(shù),那么默認(rèn)使用 --mixed 參數(shù)。此時(shí)表示要:保留工作目錄,并清空暫存區(qū)。

特別提示

HEAD指向的版本就是當(dāng)前版本,因此,Git允許我們在版本的歷史之間穿梭,使用命令
git reset --hard commit_id

穿梭前,用git log可以查看提交歷史,以便確定要回退到哪個(gè)版本。
要重返未來,用git reflog查看命令歷史,以便確定要回到未來的哪個(gè)版本。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。