63.Git Reset 詳解版本回滾的三種模式

git reset

意思就是可以讓HEAD這個指針指向其他版本。說白了就是通過此命令在版本之間進(jìn)行穿梭。
它有三種模式,soft,mixed,hard过椎,具體的使用方法下面這張圖,展示的很全面了戏仓。

git各個區(qū)域和命令關(guān)系

這三個模式理解了疚宇,對于使用這個命令很有幫助。在理解這三個模式之前赏殃,需要略微知道一點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 所帶來的新的差異」特纤?就是這里:

--soft所帶來的新的差異

由于 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查看命令歷史斥铺,以便確定要回到未來的哪個版本彻桃。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市晾蜘,隨后出現(xiàn)的幾起案子邻眷,更是在濱河造成了極大的恐慌,老刑警劉巖剔交,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肆饶,死亡現(xiàn)場離奇詭異,居然都是意外死亡岖常,警方通過查閱死者的電腦和手機(jī)驯镊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人板惑,你說我怎么就攤上這事橄镜。” “怎么了冯乘?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵蛉鹿,是天一觀的道長。 經(jīng)常有香客問我往湿,道長,這世上最難降的妖魔是什么惋戏? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任领追,我火速辦了婚禮,結(jié)果婚禮上响逢,老公的妹妹穿的比我還像新娘绒窑。我一直安慰自己,他們只是感情好舔亭,可當(dāng)我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布些膨。 她就那樣靜靜地躺著,像睡著了一般钦铺。 火紅的嫁衣襯著肌膚如雪订雾。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天矛洞,我揣著相機(jī)與錄音洼哎,去河邊找鬼。 笑死沼本,一個胖子當(dāng)著我的面吹牛噩峦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播抽兆,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼识补,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了辫红?” 一聲冷哼從身側(cè)響起凭涂,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎厉熟,沒想到半個月后导盅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡揍瑟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年白翻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡滤馍,死狀恐怖岛琼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巢株,我是刑警寧澤槐瑞,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站阁苞,受9級特大地震影響困檩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜那槽,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一悼沿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧骚灸,春花似錦糟趾、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至丈钙,卻和暖如春非驮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背著恩。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工院尔, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人喉誊。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓邀摆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親伍茄。 傳聞我的和親對象是個殘疾皇子栋盹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,724評論 2 351