如何撤銷 Git重置
How can I undo git reset --hard HEAD~1?
要了解可不可撤銷Git的操作竞端,那就需要先了解是如何進行的循签。
Git reset
命令用于將當前分支回退到指定的某個版本。
git reset [--soft | --mixed | --hard] [commitversion]
git reset --hard HEAD~1
配圖
reset
reset
命令可以看做commit命令的取反操作逐哈,既然可以向前提交衬以,當然也可以向后回滾攒庵。
可以像事務一樣回滾一次到上一次的位置,也可以回滾到指定的位置几睛。
這個位置由commitversion決定房轿,每commit一次都會產生一個commitversion值。
1 --soft,--mixed,--hard這幾個選項會改變reset命令的行為模式:配圖說明三個區(qū)
--hard
--hard選項在幫助文檔中的解釋是:
- Resets the index and working tree. Any changes to tracked files in the working tree since <commit> are discarded.
具體來說會執(zhí)行三個動作:
(1) 替換引用的指向所森。引用指向新的提交ID囱持。
(2) 替換暫存區(qū)。替換后必峰,暫存區(qū)的內容和引用指向的目錄樹一致洪唐。
(3) 替換工作區(qū)。替換后吼蚁,工作區(qū)的內容變得和暫存區(qū)一致凭需,也和commitversion所指向的目錄樹內容相同。
--soft
--soft選項只更改引用的指向肝匆,不改變暫存區(qū)和工作區(qū)粒蜈。
--mixed(默認)
--mixed那么當前分支被回滾到指定commitversion,暫存區(qū)被重置旗国,但是工作區(qū)文件不變枯怖。
2 commitversion是指定曾經commit的版本,每次commit都會產生唯一一個commitversion能曾,用于標識本次commit度硝。
(1) 那么怎樣找到每次commit的commitversion呢?
有兩個命令都可以達到這個目標:git log 和git reflog寿冕。
:配圖說明怎么獲取log
git log [--pretty=oneline]
git reflog
//用例
用法分別是:
git log查看的日志是相對于當前commitversion之前的所有歷史日志蕊程,
git reflog查看的日志是相對于最后一個commitversion之前的所有歷史日志。
展開來講就是驼唱,一個是相對歷史日志藻茂,一個是絕對歷史日志。假如你已經reset到某個commitversion了,那么這個時候使用git log只能看到這個commitversion之前的歷史日志辨赐,看不到之后的歷史日志了优俘,但是使用git reflog就可以。
(2) git對離當前版本最近的commitversion提供了快捷方式掀序。
在Git中帆焕,用HEAD表示當前版本,也就是最新的提交森枪,上一個版本就是HEAD视搏,上上一個版本就是HEAD,當然往上100個版本寫100個比較容易數不過來县袱,所以寫成HEAD~100浑娜。
比如撤銷到上一個版本:
git reset --hard HEAD^
或者
git reset --hard HEAD~1
比如恢復撤銷到上一本版本:
git reset --hard HEAD@{1}
(3) 如果省略commitversion,相當于指定最新版本HEAD式散,即git reset == git reset --mixed HEAD筋遭。引用被指向最新提交版本即HEAD,相當于不改變引用位置暴拄;暫存區(qū)被替換為最新的HEAD的目錄樹漓滔,相當于當前已add或rm但是未commit的改動被撤出暫存區(qū),可以看做git add的取反操作乖篷。
擴展用法
有時工作空間的工程會由開發(fā)工具產生一些最新的文件或目錄响驴,這些文件或目錄是不納入git版本管理范圍內的,所以對于電腦當前的工作空間撕蔼,有時使用git reset命令在某些操作系統(tǒng)上不一定能完全回退豁鲤,需要一個額外的操作幫助git回退,這個命令是:
git clean -dfx
用于強制清洗當前工作區(qū)不受git管理的文件或目錄鲸沮,幫助git將當前工作區(qū)干凈的回退到指定commitversion琳骡。
懸掛提交 也就是說,這個提交沒有任何分支指向它讼溺。配圖說明
下次Git執(zhí)行垃圾回收的時候楣号,git會發(fā)現(xiàn)這個提交沒有被跟蹤,將會刪除它怒坯。
撤銷與恢復
:配圖操作
后撤
git reset --hard HEAD~1
恢復
git reset --hard HEAD@{1}
HEAD@{1} 指代碼的是前一次操作
花了我一段時間去理解HEAD@{1}和HEAD~1之間的差異是 前一個版本和后一個版本
這樣你可以輕松的前一步炫狱,后一步的操作了而不必記得具體的SHA1
這個值你可以在LOG輸出里看到
Git在線學習
另外推存一個GIT學習的小游戲吧。通過完成學習剔猿,任務毕荐。輕松掌握各Git操作技能。