1. 程式人生 > >git reset本地常見操作

git reset本地常見操作

git reset命令用於將當前分支回退到指定的某個版本。

基本用法

git reset [--soft | --mixed | --hard] [commitversion]

詳解

該命令可以看做commit命令的取反操作,既然可以向前提交,當然也可以向後回滾。可以像事務一樣回滾一次到上一次的位置,也可以回滾到指定的位置。這個位置由commitversion決定,每commit一次都會產生一個commitversion值。

1 --soft,--mixed,--hard這幾個選項會改變reset命令的行為模式:
如果用--hard選項,--hard選項在幫助文件中的解釋是:Resets the index and working tree. Any changes to tracked files in the working tree since <commit> are discarded.具體來說會執行三個動作:
(1) 替換引用的指向。引用指向新的提交ID
(2) 替換暫存區。替換後,暫存區的內容和引用指向的目錄樹一致。
(3) 替換工作區。替換後,工作區的內容變得和暫存區一致,也和commitversion所指向的目錄樹內容相同。
如果用--soft選項,只更改引用的指向,不改變暫存區和工作區。
如果用--mixed或者不給這個選項(兩者效果一樣),那麼當前分支被回滾到指定commitversion,暫存區被重置,但是工作區檔案不變。

2 commitversion是指定曾經commit的版本,每次commit都會產生唯一一個commitversion,用於標識本次commit。

(1) 那麼怎樣找到每次commit的commitversion呢?有兩個命令都可以達到這個目標:git log 和git reflog
用法分別是:
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^

(3) 如果省略commitversion,相當於指定最新版本HEAD,即git reset == git reset --mixed HEAD。引用被指向最新提交版本即HEAD,相當於不改變引用位置;暫存區被替換為最新的HEAD的目錄樹,相當於當前已add或rm但是未commit的改動被撤出暫存區,可以看做git add的取反操作。

擴充套件用法

有時工作空間的工程會由開發工具產生一些最新的檔案或目錄,這些檔案或目錄是不納入git版本管理範圍內的,所以對於電腦當前的工作空間,有時使用git reset命令在某些作業系統上不一定能完全回退,需要一個額外的操作幫助git回退,這個命令是:
git clean -dfx

用於強制清洗當前工作區不受git管理的檔案或目錄,幫助git將當前工作區乾淨的回退到指定commitversion。