git reset --soft,--hard的區(qū)別

git reset --soft,--hard的區(qū)別

git reset 命令可以將當(dāng)前的HEAD重置到特定的狀態(tài)。
首先要搞清楚下面幾個(gè)概念

  • HEAD: HEAD就是指向當(dāng)前分支當(dāng)前版本的游標(biāo)
  • Index: Index即為暫存區(qū),當(dāng)你修改了你的git倉庫里的一個(gè)文件時(shí)重窟,這些變化一開始是unstaged狀態(tài)献幔,為了提交這些修改欢唾,你需要使用git add把它加入到index鳄厌,使它成為staged狀態(tài)岂贩。當(dāng)你提交一個(gè)commit時(shí)嗤详,index里面的修改被提交个扰。
  • working tree: 即當(dāng)前的工作目錄。

git reset 的用法
git reset [<mode>] [<commit>]
git reset 將當(dāng)前分支的HEAD指向給定的版本葱色,并根據(jù)模式的不同決定是否修改index和working tree递宅。
常用的有三種模式,--soft, --mixed, --hard苍狰,如果沒有給出<mode>則默認(rèn)是--mixed

--soft

使用--soft參數(shù)將會僅僅重置HEAD到制定的版本办龄,不會修改index和working tree

38d65dd (HEAD -> master) Third commit
6bf8706 Second commit
093ceb0 First commit

例如當(dāng)前分支現(xiàn)在有三次提交,執(zhí)行git reset --soft HEAD~之后淋昭,查看git log

6bf8706 (HEAD -> master) Second commit
093ceb0 First commit

而本地文件的內(nèi)容并沒有發(fā)生變化俐填,而index中仍然有最近一次提交的修改,這時(shí)執(zhí)行g(shù)it status會顯示這些修改已經(jīng)在再暫存區(qū)中了翔忽,無需再一次執(zhí)行g(shù)it add


--mixed

使用--mixed參數(shù)與--soft的不同之處在于英融,--mixed修改了index,使其與第二個(gè)版本匹配歇式。index中給定commit之后的修改被unstaged驶悟。



如果現(xiàn)在執(zhí)行g(shù)it commit 將不會發(fā)生任何事,因?yàn)闀捍鎱^(qū)中沒有修改材失,在提交之前需要再次執(zhí)行g(shù)it add

--hard

使用--hard同時(shí)也會修改working tree痕鳍,也就是當(dāng)前的工作目錄,如果我們執(zhí)行git reset --hard HEAD~,那么最后一次提交的修改笼呆,包括本地文件的修改都會被清楚熊响,徹底還原到上一次提交的狀態(tài)且無法找回。所以在執(zhí)行reset --hard之前一定要小心

git revert

使用git revert也能起到回退版本的作用诗赌,不同之處在于

  • git revert <commit>會回退到<commit>之前的那次提交汗茄,比如git revert HEAD~3會回退到最近的第4個(gè)提交的狀態(tài),而不是第3個(gè)
  • git revert會產(chǎn)生一個(gè)新的commit境肾,將這次回退作為一次修改記錄提交剔难,這樣的好處是不修改歷史提交記錄。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末奥喻,一起剝皮案震驚了整個(gè)濱河市偶宫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌环鲤,老刑警劉巖纯趋,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異冷离,居然都是意外死亡吵冒,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門西剥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來痹栖,“玉大人,你說我怎么就攤上這事瞭空【景ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵咆畏,是天一觀的道長南捂。 經(jīng)常有香客問我,道長旧找,這世上最難降的妖魔是什么溺健? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮钮蛛,結(jié)果婚禮上鞭缭,老公的妹妹穿的比我還像新娘。我一直安慰自己愿卒,他們只是感情好缚去,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著琼开,像睡著了一般。 火紅的嫁衣襯著肌膚如雪枕荞。 梳的紋絲不亂的頭發(fā)上柜候,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天搞动,我揣著相機(jī)與錄音,去河邊找鬼渣刷。 笑死鹦肿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的辅柴。 我是一名探鬼主播箩溃,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼碌嘀!你這毒婦竟也來了涣旨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤股冗,失蹤者是張志新(化名)和其女友劉穎霹陡,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體止状,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡烹棉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了怯疤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浆洗。...
    茶點(diǎn)故事閱讀 40,115評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖集峦,靈堂內(nèi)的尸體忽然破棺而出伏社,到底是詐尸還是另有隱情,我是刑警寧澤少梁,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布洛口,位于F島的核電站,受9級特大地震影響凯沪,放射性物質(zhì)發(fā)生泄漏第焰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一妨马、第九天 我趴在偏房一處隱蔽的房頂上張望挺举。 院中可真熱鬧,春花似錦烘跺、人聲如沸湘纵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽梧喷。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間铺敌,已是汗流浹背汇歹。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留偿凭,地道東北人产弹。 一個(gè)月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像弯囊,于是被迫代替她去往敵國和親痰哨。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評論 2 355

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