Git撤銷修改場景及對應指令詳解
本文原則:開門見山、簡明扼要,希望能給大家學習工作提供幫助!
場景一:撤銷工作區的修改(未執行git add)
指令:git checkout 【目錄或檔名】
例項:
1、修改了test.txt文件,git status 會出現如下提示:
2、git checkout test.txt,無提示
3、git status,顯示乾淨的工作區
場景二:撤銷暫存區的修改(已執行git add,但未執行git commit)
指令:git reset 【HEAD或某一版本號】【可選:檔名】(HEAD指向最近的一個版本,一個commit就是一個版本,版本號可以通過git log指令查詢)
注意:git reset有三個引數,--soft、--mixed、--hard,如果不指定,會預設指行--mixed引數,它的意思是將指定版本之後的修改(在本場景中,就是最近一次提交後的修改),都撤回到工作區中,也就是未執行git add的狀態。如果加上--hard引數,就會放棄指定版本之後的所有修改,會出現乾淨的工作區與暫存區(此引數會在下個場景展示例項)。如果加上--soft引數,則會把指定版本之後的修改撤回到暫存區,工作區內容不變。
例項:
1、修改test.txt文件,並提交修改到暫存區
2、git reset HEAD
3、git status,顯示修改撤回到了工作區
場景三:撤銷已經執行git commit的修改(真正意義上的版本回退)
指令:git reset或git revert
git reset與git revert的區別:
git reset會修改git log的版本歷史,如果你回退到了幾個版本前,那git log時就會發現你丟失了被回退的版本。而git revert不會修改版本歷史,你回退哪個版本,git revert就會新建一個提交,把你要回退版本的修改抵消掉。如果沒看懂,請看例項:
例項一:git reset
1、git log --pretty=online 顯示有三個版本
2、git reset --hard 版本號(輸前幾位即可),回退版本到Second commit
3、git log --pretty=online,丟失版本Third commit
例項二:git revert
1、git log --pretty=online 顯示有三個版本
2、git revert 版本號,抵消某個版本與其之後版本的修改,注意,這裡的邏輯與git reset不一樣,如果想回到Second commit的版本,就需要抵消掉Third commit的修改。所以這裡應該git revert Third commit的版本號
3、revert的過程中可能會有衝突,git status檢視衝突位置,解決衝突,git commit 檔名(無需git add)
4、git log --pretty=online,Third commit並沒有丟失,而是多了一個revert版本,你可以 git log -p檢視每個版本的修改,發現revert的版本所做的修改與Third commit恰恰相反,正好抵消掉了它的修改。
忠告:如果你的回退涉及到了遠端分支,在版本回退時最好使用revert,因它沒有修改版本歷史;如果使用reset,因為你的reset操作,會使你比遠端少了幾個提交,遠端會提示你落後於遠端版本,應該先git pull程式碼,那麼你的reset操作又有何意義呢?(git push -f 強推可以做到,但不推薦這樣做)