git撤回幾種方法

目錄

1. 工作區(qū)和暫存區(qū)

2. Git撤回方法

2.1. git reset --soft

2.2. git reset --mix(default)

2.3. git reset --hard

2.4. git checkout --

2.5.git revert

3. 總結(jié)

常言道桐早,君子一言駟馬難追活逆,世上沒(méi)有后悔的藥。但是在git的世界,你卻有一架時(shí)光機(jī),可以自由地在過(guò)去和未來(lái)之間穿梭。本文主要講解git撤回方法,將從原理進(jìn)行分析,以及仔細(xì)分析多種撤回方法的區(qū)別焚刺。

1. 工作區(qū)和暫存區(qū)

當(dāng)我們修改一個(gè)文件時(shí),通常第一步需要先git add命令把文件添加進(jìn)去门烂,然后再git commit提交更改乳愉。那么這些命令究竟做了什么事情呢?

git作為一個(gè)版本控制系統(tǒng),通過(guò)隱藏的.git文件構(gòu)建了一個(gè)版本庫(kù)屯远。工作區(qū)是指電腦里面能看到的本地工作目錄蔓姚,版本庫(kù)是由.git文件構(gòu)建,這個(gè)文件通常隱藏在工作區(qū)慨丐。版本庫(kù)中有個(gè)很重要的暫存區(qū)(stage)和分支坡脐。

我們?cè)诒镜仉娔X工作目錄修改一個(gè)readme.txt文件,新增一個(gè)LiCENSE文件房揭,使用git status查看一下?tīng)顟B(tài)备闲,代碼有一個(gè)文件修改了晌端,有一個(gè)文件增加等待加到staged。

admindeMacBook-Pro-5:learngit hzjdemac$ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

    modified:   readme.txt

Untracked files:
  (use "git add <file>..." to include in what will be committed)

    LICENSE

no changes added to commit (use "git add" and/or "git commit -a")

使用git add命令恬砂,實(shí)際上就是把文件修改從本地工作區(qū)添加到暫存區(qū)咧纠。使用git status查看一下?tīng)顟B(tài), 如圖所示stage里面多了兩個(gè)文件等待commit。

admindeMacBook-Pro-5:learngit hzjdemac$ git status
On branch master
Changes to be committed:
 (use "git reset HEAD <file>..." to unstage)

   new file:   LICENSE
   modified:   readme.txt
image.png

第二步是用git commit提交更改泻骤,實(shí)際上就是把暫存區(qū)的所有內(nèi)容提交到當(dāng)前分支,此時(shí)用git status查看漆羔,則stage空空如也。使用git log命令則多了一條日志

admindeMacBook-Pro-5:learngit hzjdemac$ git status
On branch master
nothing to commit, working tree clean
admindeMacBook-Pro-5:learngit hzjdemac$ git log
commit dfe491b3581352276e5985f2b4a2057e2b3974f8 (HEAD -> master)
Author: wong
Date:   Wed Nov 14 11:21:52 2018 +0800

    add file

commit 367dce4c74da9a81a370a24b0655598796c25181
Author: wong
Date:   Wed Nov 14 11:14:19 2018 +0800

    wrote a readme file
image
image

2. Git撤回方法

reset命令能夠?qū)EAD(當(dāng)前分支的版本頂端)移動(dòng)到另外一個(gè)commit,reset在一條分支上前后移動(dòng)狱掂, 與checkout 移到到其他分支是不同的演痒。本文主要講解撤回,所以討論的是往后移動(dòng) 符欠。下面將解釋幾個(gè)參數(shù)的不同嫡霞。

image
image

2.1. git reset --soft

使用--soft參數(shù),則會(huì)將HEAD到另外一個(gè)commit之間提交的修改返回到stage希柿,說(shuō)白了就是與git commit -m 命令功能剛剛相反。

admindeMacBook-Pro-5:learngit hzjdemac$ git reset --soft HEAD~1
admindeMacBook-Pro-5:learngit hzjdemac$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

    new file:   LICENSE
    modified:   readme.txt

使用git log命令可以發(fā)現(xiàn)剛才的提交沒(méi)有了养筒,一切回到了沒(méi)有發(fā)生過(guò)的狀態(tài)曾撤。但是這是錯(cuò)覺(jué),使用git reflog還是可以找到提交的痕跡晕粪,并回到最初的起點(diǎn)挤悉。

2.2. git reset --mix(default)

使用--mix參數(shù),則會(huì)將HEAD到另外一個(gè)commit之間提交的修改和stage內(nèi)容返回到本地工作區(qū)巫湘,說(shuō)白了就是git commit -m, git add 命令功能剛剛相反装悲。

代碼塊

admindeMacBook-Pro-5:learngit hzjdemac$ git reset 367dce4c74da9a81
Unstaged changes after reset:
M   readme.txt
admindeMacBook-Pro-5:learngit hzjdemac$ git status
On branch master
Changes not staged for commit:
 (use "git add <file>..." to update what will be committed)
 (use "git checkout -- <file>..." to discard changes in working directory)

   modified:   readme.txt

Untracked files:
 (use "git add <file>..." to include in what will be committed)

   LICENSE

no changes added to commit (use "git add" and/or "git commit -a")

2.3. git reset --hard

使用hard命令,移動(dòng)HEAD到另外一個(gè)commit時(shí)尚氛,會(huì)強(qiáng)制本地工作區(qū)進(jìn)行同步诀诊,清空stage,此時(shí)本地工作區(qū)數(shù)據(jù)和版本庫(kù)中分支數(shù)據(jù)保持一致阅嘶。這是一個(gè)比較危險(xiǎn)的動(dòng)作属瓣,如果本地新加的修改沒(méi)有保存的話,數(shù)據(jù)會(huì)丟失讯柔,永遠(yuǎn)找不回來(lái)了抡蛙。使用此命令最好先把最近修改commit一下,以后通過(guò)git reflog還能夠找回魂迄。

2.4. git checkout --

使用此命名會(huì)撤銷本地工作區(qū)的修改粗截。當(dāng)你修改了一個(gè)文件,準(zhǔn)備提交時(shí)捣炬,猛然發(fā)現(xiàn)錯(cuò)誤熊昌。幸虧發(fā)現(xiàn)得及時(shí)怠晴,使用git checkout --撤銷剛才的修改,回到上一次git commit或者git add的狀態(tài)浴捆。

2.5.git revert

要撤回中間的某次提交蒜田,此次操作之前和之后的commit和history都會(huì)保留,并且把這次撤銷作為一次最新的提交选泻。注意撤回的提交真的被拋棄了冲粤,本地工作區(qū)和stage都不會(huì)有記錄,使用git revert有可能會(huì)引起沖突页眯。

代碼塊

admindeMacBook-Pro-5:learngit hzjdemac$ git log
commit 105262a03ca8a99081669260f795021fa1fd73ec (HEAD -> master)
Author: wong
Date:   Wed Nov 14 13:23:15 2018 +0800

    Revert "add test"

    This reverts commit f03b82e7628cc88fa025f82782e06bdd55d97948.

commit c7ed83816bb856a992009c548e30694fc185dafd
Author: wong
Date:   Wed Nov 14 13:22:59 2018 +0800

    stage:

commit f03b82e7628cc88fa025f82782e06bdd55d97948
Author: wong
Date:   Wed Nov 14 13:21:42 2018 +0800

    add test

commit dfe491b3581352276e5985f2b4a2057e2b3974f8
Author: wong
Date:   Wed Nov 14 11:21:52 2018 +0800

    add file

commit 367dce4c74da9a81a370a24b0655598796c25181
Author: wong
Date:   Wed Nov 14 11:14:19 2018 +0800

    wrote a readme file

3. 總結(jié)

修改保存在本地工作區(qū)梯捕,使用git checkout --撤銷修改

已保存到了stage, 使用git reset [--mix] HEAD 將修改文件打回本地工作區(qū);

已保存到了分支窝撵,使用git reset [--mix] HEAD~1將修改文件打回本地工作區(qū)傀顾;

要拋棄最近提交,使用git reset [--hard] HEAD~1將上一次提交同步到本地工作區(qū)碌奉;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末短曾,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子赐劣,更是在濱河造成了極大的恐慌嫉拐,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件魁兼,死亡現(xiàn)場(chǎng)離奇詭異婉徘,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)咐汞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門盖呼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人化撕,你說(shuō)我怎么就攤上這事几晤。” “怎么了侯谁?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵锌仅,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我墙贱,道長(zhǎng)热芹,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任惨撇,我火速辦了婚禮伊脓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己报腔,他們只是感情好株搔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著纯蛾,像睡著了一般狂秘。 火紅的嫁衣襯著肌膚如雪睛竣。 梳的紋絲不亂的頭發(fā)上席函,一...
    開(kāi)封第一講書(shū)人閱讀 51,727評(píng)論 1 305
  • 那天窗价,我揣著相機(jī)與錄音,去河邊找鬼碰煌。 笑死舒岸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的芦圾。 我是一名探鬼主播蛾派,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼个少!你這毒婦竟也來(lái)了洪乍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤稍算,失蹤者是張志新(化名)和其女友劉穎典尾,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體糊探,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年河闰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了科平。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡姜性,死狀恐怖瞪慧,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情部念,我是刑警寧澤弃酌,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站儡炼,受9級(jí)特大地震影響妓湘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜乌询,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一榜贴、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧妹田,春花似錦唬党、人聲如沸鹃共。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)霜浴。三九已至,卻和暖如春蓝纲,著一層夾襖步出監(jiān)牢的瞬間阴孟,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工驻龟, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留温眉,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓翁狐,卻偏偏與公主長(zhǎng)得像类溢,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子露懒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Git常用語(yǔ)法 [TOC] Git簡(jiǎn)介 描述 ? Git(讀音為/g?t/闯冷。)是一個(gè)開(kāi)源的分布式版本控制系統(tǒng),...
    君惜丶閱讀 3,529評(píng)論 0 13
  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git懈词,從https:/...
    落魂灬閱讀 12,665評(píng)論 4 54
  • 職場(chǎng)趣聞 A:同事加班蛇耀,眼看著要下雨了,就去買了一把傘坎弯,沒(méi)想到計(jì)劃趕不上變化纺涤,這傘算是白買了 B:“后來(lái)沒(méi)下雨嗎”...
    冷風(fēng)來(lái)閱讀 336評(píng)論 0 0
  • 在影院看到想看的動(dòng)畫(huà)撩炊,可以算得上有生之年了。和以往新海誠(chéng)的動(dòng)畫(huà)一致崎脉,對(duì)于我而言拧咳,總需要不斷的Again才能慢慢入戲...
    冰凝雪國(guó)閱讀 263評(píng)論 0 1
  • EOF 在getchar()之前,先討論EOF的概念.EOF(End Of File)表示的是文件結(jié)束符. 不同于...
    deffisoan閱讀 330評(píng)論 0 0