git reset
意思就是可以讓HEAD這個指針指向其他版本。說白了就是通過此命令在版本之間進(jìn)行穿梭。
它有三種模式,soft,mixed,hard过椎,具體的使用方法下面這張圖,展示的很全面了戏仓。
這三個模式理解了疚宇,對于使用這個命令很有幫助。在理解這三個模式之前赏殃,需要略微知道一點Git的基本流程敷待。正如上圖,Git會有三個區(qū)域:
Working Tree 當(dāng)前的工作區(qū)域
Index/Stage 暫存區(qū)域仁热,和git stash命令暫存的地方不一樣榜揖。使用git add xx,就可以將xx添加近Stage里面
Repository 提交的歷史抗蠢,即使用git commit提交后的結(jié)果
1. git reset --hard
首先举哟,Git
必須知道當(dāng)前版本是哪個版本,在Git
中迅矛,用HEAD
表示當(dāng)前版本妨猩,上一個版本就是HEAD^
,上上一個版本就是HEAD^^
秽褒,以此類推壶硅,當(dāng)然往上100個版本寫100個^
比較容易數(shù)不過來,所以寫成HEAD~100
销斟。
--hard
會在重置 HEAD 和branch的同時庐椒,重置緩存區(qū)和工作目錄里的內(nèi)容。當(dāng)你在 reset 后面加了--hard
參數(shù)時蚂踊,你的緩存區(qū)和工作目錄里的內(nèi)容會被完全重置為和HEAD的新位置相同的內(nèi)容约谈。換句話說,就是你的沒有commit的修改會被全部擦掉犁钟。
回退到上一版本:
git reset --hard HEAD^
回退到指定版本號(以1a2b3c為例)的版本:
git reset --hard 1a2b3c
reset --hard:重置stage區(qū)和工作目錄:
2. git reset --soft
--soft
則會保留工作目錄的內(nèi)容棱诱,并把因為重置 HEAD 所帶來的新的文件差異放進(jìn)暫存區(qū)。
什么是「重置 HEAD 所帶來的新的差異」特纤?就是這里:
由于 HEAD 從 4 移動到了 3军俊,而且在 reset 的過程中工作目錄和暫存區(qū)的內(nèi)容沒有被清理掉,所以 4 中的改動在 reset 后就也成了工作目錄新增的「工作目錄和 HEAD 的差異」捧存。這就是上面一段中所說的「重置 HEAD 所帶來的差異」粪躬。
這就是--soft 和 --hard 的區(qū)別:--hard 會清空工作目錄和暫存區(qū)的改動,*而 --soft則會保留工作目錄的內(nèi)容,并把因為保留工作目錄內(nèi)容所帶來的新的文件差異放進(jìn)暫存區(qū)昔穴。
3.git reset 不帶參數(shù)或帶--mixed
git reset 如果不加參數(shù)镰官,那么默認(rèn)使用 --mixed 參數(shù)。此時表示要:保留工作目錄吗货,并清空暫存區(qū)泳唠。也就是說,工作目錄的修改宙搬、暫存區(qū)的內(nèi)容以及由 reset 所導(dǎo)致的新的文件差異笨腥,都會被放進(jìn)工作目錄拓哺。簡而言之,就是「把所有差異都混合(mixed)放在工作目錄中」脖母。
總結(jié)
首先士鸥,Git
必須知道當(dāng)前版本是哪個版本,在Git
中谆级,用HEAD
表示當(dāng)前版本烤礁,上一個版本就是HEAD^
,上上一個版本就是HEAD^^
肥照,以此類推脚仔,當(dāng)然往上100個版本寫100個^
比較容易數(shù)不過來,所以寫成HEAD~100
舆绎。
回退到上一版本:
git reset --hard HEAD^
回退到指定版本號(以1a2b3c為例)的版本:
git reset --hard 1a2b3c
--hard 會清空工作目錄和暫存區(qū)的改動,
--soft則會保留工作目錄的內(nèi)容鲤脏,并把因為保留工作目錄內(nèi)容所帶來的新的文件差異放進(jìn)暫存區(qū)。
--mixed 參數(shù)亿蒸。git reset 如果不加參數(shù)凑兰,那么默認(rèn)使用 --mixed 參數(shù)。此時表示要:保留工作目錄边锁,并清空暫存區(qū)姑食。
特別提示
HEAD指向的版本就是當(dāng)前版本,因此茅坛,Git允許我們在版本的歷史之間穿梭音半,使用命令
git reset --hard commit_id
穿梭前,用git log
可以查看提交歷史贡蓖,以便確定要回退到哪個版本曹鸠。
要重返未來,用git reflog
查看命令歷史斥铺,以便確定要回到未來的哪個版本彻桃。