Git 一張圖看明白Git的四個(gè)區(qū)五種狀態(tài)

為什么需要用到git娜扇?

情景1: 緊急修復(fù)線上BUG(分支的新建與合并)

現(xiàn)在讓我們來(lái)看一個(gè)簡(jiǎn)單的分支與合并的例子越妈,實(shí)際工作中大體也會(huì)用到這樣的工作流程:

  1. 開(kāi)發(fā)某個(gè)網(wǎng)站季俩。
  2. 為實(shí)現(xiàn)某個(gè)新的需求,創(chuàng)建一個(gè)分支梅掠。
  3. 在這個(gè)分支上開(kāi)展工作酌住。

假設(shè)此時(shí),你突然接到一個(gè)電話說(shuō)有個(gè)很?chē)?yán)重的問(wèn)題需要緊急修補(bǔ)阎抒,那么可以按照下面的方式處理:

  1. 返回到原先已經(jīng)發(fā)布到生產(chǎn)服務(wù)器上的分支酪我。
  2. 為這次緊急修補(bǔ)建立一個(gè)新分支,并在其中修復(fù)問(wèn)題且叁。
  3. 通過(guò)測(cè)試后都哭,回到生產(chǎn)服務(wù)器所在的分支,將修補(bǔ)分支合并進(jìn)來(lái)逞带,然后再推送到生產(chǎn)服務(wù)器上欺矫。
  4. 切換到之前實(shí)現(xiàn)新需求的分支,繼續(xù)工作展氓。

具體操作方式 鏈接


五種狀態(tài)間的順序操作

四個(gè)區(qū)

    1. 工作區(qū)(Working Area)
    1. 暫存區(qū)(Stage)
    1. 本地倉(cāng)庫(kù)(Local Repository)
    1. 遠(yuǎn)程倉(cāng)庫(kù)(Remote Repository)

五種狀態(tài)

    1. 未修改(Origin)
    1. 已修改(Modified)&未追蹤(Untracked)
    1. 已暫存(Staged)
    1. 已提交(Committed)
    1. 已推送(Pushed)

順序操作

  • 第零步:工作區(qū)與倉(cāng)庫(kù)保持一致
  • 第一步:文件增刪改穆趴,變?yōu)橐研薷臓顟B(tài)
  • 第二步:git add ,變?yōu)橐褧捍鏍顟B(tài)
$ git add --all # 當(dāng)前項(xiàng)目下的所有更改
$ git add .  # 當(dāng)前目錄下的所有更改
$ git add xx/xx.py xx/xx2.py  # 添加某幾個(gè)文件

  • 第三步:git commit遇汞,變?yōu)橐烟峤粻顟B(tài)
$ git commit -m"<這里寫(xiě)commit的描述>"

  • 第四步:git push未妹,變?yōu)橐淹扑蜖顟B(tài)
$ git push -u origin master # 第一次需要關(guān)聯(lián)上
$ git push # 之后再推送就不用指明應(yīng)該推送的遠(yuǎn)程分支了
$ git branch # 可以查看本地倉(cāng)庫(kù)的分支
$ git branch -a # 可以查看本地倉(cāng)庫(kù)和本地遠(yuǎn)程倉(cāng)庫(kù)(遠(yuǎn)程倉(cāng)庫(kù)的本地鏡像)的所有分支

git

五種狀態(tài)間的撤銷(xiāo)操作

已修改,但未暫存

$ git diff # 列出所有的修改
$ git diff xx/xx.py xx/xx2.py # 列出某(幾)個(gè)文件的修改

$ git checkout # 撤銷(xiāo)項(xiàng)目下所有的修改
$ git checkout . # 撤銷(xiāo)當(dāng)前文件夾下所有的修改
$ git checkout xx/xx.py xx/xx2.py # 撤銷(xiāo)某幾個(gè)文件的修改
$ git clean -f # untracked狀態(tài)勺疼,撤銷(xiāo)新增的文件
$ git clean -df # untracked狀態(tài)教寂,撤銷(xiāo)新增的文件和文件夾

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

已暫存,未提交

這個(gè)時(shí)候已經(jīng)執(zhí)行過(guò)git add执庐,但未執(zhí)行g(shù)it commit酪耕,但是用git diff已經(jīng)看不到任何修改。

因?yàn)間it diff檢查的是工作區(qū)與暫存區(qū)之間的差異轨淌。

$ git diff --cached # 這個(gè)命令顯示暫存區(qū)和本地倉(cāng)庫(kù)的差異

$ git reset # 暫存區(qū)的修改恢復(fù)到工作區(qū)
$ git reset --soft # 與git reset等價(jià)迂烁,回到已修改狀態(tài),修改的內(nèi)容仍然在工作區(qū)中
$ git reset --hard # 回到未修改狀態(tài)递鹉,清空暫存區(qū)和工作區(qū)

git reset --hard 操作等價(jià)于 git reset 和 git checkout 2步操作

已提交盟步,未推送

執(zhí)行完commit之后,會(huì)在倉(cāng)庫(kù)中生成一個(gè)版本號(hào)(hash值)躏结,標(biāo)志這次提交却盘。之后任何時(shí)候,都可以借助這個(gè)hash值回退到這次提交。

$ git diff <branch-name1> <branch-name2> # 比較2個(gè)分支之間的差異
$ git diff master origin/master # 查看本地倉(cāng)庫(kù)與本地遠(yuǎn)程倉(cāng)庫(kù)的差異

$ git reset --hard origin/master # 回退與本地遠(yuǎn)程倉(cāng)庫(kù)一致
$ git reset --hard HEAD^ # 回退到本地倉(cāng)庫(kù)上一個(gè)版本
$ git reset --hard <hash code> # 回退到任意版本
$ git reset --soft/git reset # 回退且回到已修改狀態(tài)黄橘,修改仍保留在工作區(qū)中兆览。

已推送到遠(yuǎn)程

$ git push -f orgin master # 強(qiáng)制覆蓋遠(yuǎn)程分支
$ git push -f # 如果之前已經(jīng)用 -u 關(guān)聯(lián)過(guò),則可省略分支名

慎用塞关,一般情況下抬探,本地分支比遠(yuǎn)程要新,所以可以直接推送到遠(yuǎn)程帆赢,但有時(shí)推送到遠(yuǎn)程后發(fā)現(xiàn)有問(wèn)題小压,進(jìn)行了版本回退,舊版本或者分叉版本推送到遠(yuǎn)程椰于,需要添加 -f參數(shù)怠益,表示強(qiáng)制覆蓋。

總結(jié)

  • 首先瘾婿,先用git status查看下當(dāng)前狀態(tài)溉痢。
  • git reset可以作用于本地倉(cāng)庫(kù),用于回退/前進(jìn)到任意版本憋他,也可以作用于暫存區(qū)孩饼,用于撤銷(xiāo)暫存區(qū)修改。有hard和soft2個(gè)參數(shù)竹挡。soft參數(shù)可以省略镀娶,soft參數(shù)表示撤銷(xiāo)的修改仍放在工作區(qū)中。
  • git checkout用于撤銷(xiāo)刪除和修改揪罕,git clean -df用于撤銷(xiāo)新增梯码。
  • git diff可以查看工作區(qū)、暫存區(qū)好啰、倉(cāng)庫(kù)之間的修改和差異轩娶,參數(shù)不同。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末框往,一起剝皮案震驚了整個(gè)濱河市鳄抒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌椰弊,老刑警劉巖许溅,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異秉版,居然都是意外死亡贤重,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)清焕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)并蝗,“玉大人祭犯,你說(shuō)我怎么就攤上這事」鐾#” “怎么了盹憎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)铐刘。 經(jīng)常有香客問(wèn)我,道長(zhǎng)影晓,這世上最難降的妖魔是什么镰吵? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮挂签,結(jié)果婚禮上疤祭,老公的妹妹穿的比我還像新娘。我一直安慰自己饵婆,他們只是感情好勺馆,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著侨核,像睡著了一般草穆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上搓译,一...
    開(kāi)封第一講書(shū)人閱讀 52,262評(píng)論 1 308
  • 那天悲柱,我揣著相機(jī)與錄音,去河邊找鬼些己。 笑死豌鸡,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的段标。 我是一名探鬼主播涯冠,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼逼庞!你這毒婦竟也來(lái)了蛇更?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤赛糟,失蹤者是張志新(化名)和其女友劉穎械荷,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體虑灰,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吨瞎,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了穆咐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片颤诀。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡字旭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出崖叫,到底是詐尸還是另有隱情遗淳,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布心傀,位于F島的核電站屈暗,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏脂男。R本人自食惡果不足惜养叛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宰翅。 院中可真熱鬧弃甥,春花似錦、人聲如沸汁讼。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)嘿架。三九已至瓶珊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間耸彪,已是汗流浹背艰毒。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搜囱,地道東北人丑瞧。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像蜀肘,于是被迫代替她去往敵國(guó)和親绊汹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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