HEAD基礎(chǔ)
git checkout
實(shí)際上是修改HEAD文件的內(nèi)容,讓其指向不同的branch院刁。HEAD文件指向的branch就是當(dāng)前branch翔始。
一般來講彪置,HEAD的內(nèi)容是指向staging(暫存區(qū))的master文件的
# 查看當(dāng)前HEAD指向
$ cat .git/HEAD
ref: refs/heads/dev
當(dāng)然也可指向其他索引文件斩箫,不管怎么樣吏砂,這個(gè)索引文件的內(nèi)容又由git reset
控制。
通過git branch
命令看到的結(jié)果和HEAD文件內(nèi)容一致乘客。
# 查看分支詳情
$ git branch -v
* dev c909fd3 add c
master 83428ce add e
# 查看工作區(qū)狐血、暫存區(qū)和HEAD的差異
$ git checkout
M b.py
detached HEAD
如果讓HEAD文件指向一個(gè)commit id,那就變成了detached HEAD易核。git checkout 可以達(dá)到這個(gè)效果匈织,用下面的命令:
# 切換指定commit的前一個(gè)commmit ^指的是前一個(gè) ^^前兩個(gè)
$ git checkout dev^^
or
$ git checkout deab1f9890^^ # deab1f9是dev分支最后一個(gè)提交的commit
Note: checking out 'dev^^'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:
git checkout -b <new-branch-name>
HEAD is now at 439ac73... add b
# 查看分支詳情
$ git branch -v
* (HEAD detached at 439ac73) 439ac73 add b
dev deab1f9 update
master 83428ce add e
注意
現(xiàn)在head已經(jīng)指向commit b,這就是所謂的dedatched head狀態(tài)牡直。從這里我們也可以看出缀匕,head是當(dāng)前index的狀態(tài),而不是當(dāng)前分支(的最近c(diǎn)ommit節(jié)點(diǎn))碰逸。這僅僅意味著head指向某個(gè)特定的commit點(diǎn)乡小,而不是指向每一個(gè)特定的分支(的頂端節(jié)點(diǎn))。如果我們此時(shí)提交一個(gè)commit花竞,只能被head索引到劲件,不屬于任何一個(gè)分支掸哑。當(dāng)然约急,我們還可以給在這個(gè)“無名分支”的基礎(chǔ)上繼續(xù)提交。
git checkout master
我們一定要注意苗分,剛在提交的commit已經(jīng)處于無法被索引到的狀態(tài)厌蔽。最終將被git的默認(rèn)回收機(jī)制所回收,除非我們?cè)谒鼈儽换厥罩皠?chuàng)建一個(gè)指向他們的索引摔癣。如果我們沒有從剛才的commit離開的話奴饮,可以用接下來的命令創(chuàng)建一個(gè)指向的索引
# 創(chuàng)建來一個(gè)foo分支,指向f择浊,接著更新head指向分支foo戴卜,此時(shí),我們不再處在detached head的狀態(tài)
$ git checkout -b foo
# 同樣創(chuàng)建了一個(gè)foo分支琢岩,但是head仍然指向master分支投剥,仍然處在detached head的狀態(tài)
$ git checkout foo
# 創(chuàng)建了一個(gè)新標(biāo)簽foo,仍處于detached的狀態(tài)
$ git tag foo
如果已經(jīng)離開了detached HEAD狀態(tài)下的commit担孔,我們先要回到commit才可以創(chuàng)建指向它的索引
查看最近head指向的commit點(diǎn)
$ git log -g -2 HEAD
or
$ git reflog -2 HEAD
恢復(fù)
# 恢復(fù)
$ git checkout dev
M b.py
Previous HEAD position was c909fd3... add c
Switched to branch 'dev'