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

git reset

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

git各個區域和命令關系

這三個模式理解瞭,對於使用這個命令很有幫助。在理解這三個模式之前,需要略微知道一點Git的基本流程。正如上圖,Git會有三個區域:

Working Tree 當前的工作區域Index/Stage 暫存區域,和git stash命令暫存的地方不一樣。使用git add xx,就可以將xx添加近Stage裡面Repository 提交的歷史,即使用git commit提交後的結果

1. git reset --hard

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

--hard 會在重置 HEAD 和branch的同時,重置緩存區和工作目錄裡的內容。當你在 reset 後面加瞭--hard 參數時,你的緩存區和工作目錄裡的內容會被完全重置為和HEAD的新位置相同的內容。換句話說,就是你的沒有commit的修改會被全部擦掉。

回退到上一版本:

git reset --hard HEAD^

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

git reset --hard 1a2b3c

reset --hard:重置stage區和工作目錄:

2. git reset --soft

--soft 則會保留工作目錄的內容,並把因為重置 HEAD 所帶來的新的文件差異放進暫存區。什麼是「重置 HEAD 所帶來的新的差異」?就是這裡:

--soft所帶來的新的差異

由於 HEAD 從 4 移動到瞭 3,而且在 reset 的過程中工作目錄和暫存區的內容沒有被清理掉,所以 4 中的改動在 reset 後就也成瞭工作目錄新增的「工作目錄和 HEAD 的差異」。這就是上面一段中所說的「重置 HEAD 所帶來的差異」。

這就是--soft 和 --hard 的區別:--hard 會清空工作目錄和暫存區的改動,*而 --soft則會保留工作目錄的內容,並把因為保留工作目錄內容所帶來的新的文件差異放進暫存區。

3.git reset 不帶參數或帶--mixed

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

總結

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

回退到上一版本:

git reset --hard HEAD^

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

git reset --hard 1a2b3c

--hard 會清空工作目錄和暫存區的改動,--soft則會保留工作目錄的內容,並把因為保留工作目錄內容所帶來的新的文件差異放進暫存區。--mixed 參數。git reset 如果不加參數,那麼默認使用 --mixed 參數。此時表示要:保留工作目錄,並清空暫存區。

特別提示

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

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

发表回复

相关推荐

减肥分享 | 从130斤到95斤,不用节食就能做到

过完年最怕的就是称体重了,虽然不愿意面对这个事实… …但突然就紧绷的袖子、裤腰和裤腿无时不刻都在提醒着你 胖 了

· 4秒前

關於誠信的名言警句

  01、沒有一處遺產像誠實那樣豐富的瞭。——莎士比亞  02、意志薄弱的人,一定不會誠實。——拉羅什夫利  03、信用既是無...

· 1分钟前

求導,微分,積分的區別

導數和微分在書寫的形式有些區別,如y=f(x),則為導數,書寫成dy=f(x)dx,則為微分。積分是求原函數,可以形象理解為是函數導數...

· 5分钟前

带你识别茺蔚子

茺蔚子为唇形科植物益母草Leonurus japonicus Houtt.的干燥成熟果实。秋季果实成熟时采割地上部分,晒干,打下果实,除去杂质。

· 5分钟前

企業如何做預算管理?

預算管理一、全面預算的實戰準備  1.從預算到企業  2.從預算到部門  3.從預算到個人  4.預算實戰環境 二、全面預算的...

· 9分钟前