git -- (實(shí)用)對工作區(qū)和暫存區(qū)的一些操作場景

diff差異

工作區(qū)和暫存區(qū) :  git diff 

工作區(qū)和HEAD  :  git diff  HEAD

暫存區(qū)和HEAD  :  git diff  --cached

不同分支的差異 :  git diff  dev1.0  master

不同commit的差異:git diff  sha1 sha2

指定文件: git diff sha1 sha2 -- test/ab.txt

說明:對于新增的文件渔期,其只存在于工作區(qū)贸人,且處于 Untracked 狀態(tài),Git 認(rèn)為無論是哪兩個 Git 區(qū)域之間的比對都沒有意義痘系,得到的結(jié)果是沒有區(qū)別。使用git status查看饿自;

撤銷操作

本地倉庫恢復(fù)暫存區(qū)內(nèi)容 :
git reset HEAD -- 文件名   # 對某個文件進(jìn)行恢復(fù)                    
git reset HEAD -- path    # 對某個路徑進(jìn)行恢復(fù)    
git reset HEAD            # 對所有文件進(jìn)行恢復(fù)
(使用 git diff -cached 做比較)
 
暫存區(qū)恢復(fù)工作區(qū)內(nèi)容 :  
git checkout -- 文件名     # 對某個文件進(jìn)行恢復(fù)
git checkout -- path      # 對某個路徑進(jìn)行恢復(fù) 
git checkout              # 對所有文件進(jìn)行恢復(fù)
(使用 git diff 做比較)

本地倉庫恢復(fù)工作區(qū)和暫存區(qū)內(nèi)容 :
git reset --hard HEAD
(使用 git diff HEAD 工作區(qū)和本地倉庫做比較)
              
git reset HEAD 本地倉庫對暫存區(qū)的恢復(fù)汰翠,加了--hard,對工作區(qū)也一起恢復(fù)璃俗。        

回到某個commit有兩種方式:reset和revert(恢復(fù))

git reset HEAD
git reset commit_id

git revert HEAD
git revert -n commit_id    -n 表示不立即commit奴璃,只是恢復(fù)工作區(qū)內(nèi)容。

git revert是用一次新的commit來回滾之前的commit城豁,git reset是直接刪除指定的commit苟穆。

清除工作區(qū)變化

git reset --hard HEAD
git clean -df

清除暫存區(qū)變化

git rm -r --cached .
git rm -r --cached -- index.jsp

從工作目錄中刪除所有沒有tracked過的文件和目錄-d

git clean -df 

說明:git clean經(jīng)常和git reset --hard一起結(jié)合使用. 記住reset只影響被track過的文件, 所以需要clean來刪除沒有track過的文件. 結(jié)合使用這兩個命令能讓你的工作目錄完全回到一個指定的<commit>的狀態(tài)
git clean的用法


下面轉(zhuǎn)發(fā)文件轉(zhuǎn)發(fā)自:https://www.cnblogs.com/soaeon/p/10908712.html

比較暫存區(qū)和HEAD所含文件的差異?

操作場景如下:

*   修改readme.md 文檔
    *   vi readme.md
*   加入到暫存區(qū)域
     *   git add readme.md
*   使用git diff -cached 做比較

比較工作區(qū)和暫存區(qū)所含文件的差異?

操作場景如下:

*   修改readme.md 文檔
    *   vi readme.md
*   加入到暫存區(qū)域
    *   git add readme.md
*   使用git diff 做比較

讓暫存區(qū)恢復(fù)成和HEAD的一樣雳旅?

git reset HEAD

暫存區(qū)覆蓋工作區(qū)(將工作區(qū)的修改抹掉)

操作場景如下:

*   修改 re'adme.md
    *   vi readme.md
*   比較工作區(qū)和暫存區(qū)的問價(jià)差異
    *   git diff
*   將暫存區(qū)覆蓋工作區(qū)
    *   git checkout -- readme.md
*   再次比較工作區(qū)和暫存區(qū)的差異
    *   git diff

取消暫存區(qū)部分文件的更改跟磨?

操作場景如下:

創(chuàng)建了兩個文件, 同時(shí)加入到了暫存區(qū)域攒盈, 發(fā)現(xiàn)還需要修改

soaeon@DESKTOP-FUJJTHR MINGW64 /f/gitstudy (master)
$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

        new file:   index.css
        new file:   index.js

index.css已經(jīng)加入到暫存區(qū)域了抵拘, 但是還需要修改, 我們先從暫存區(qū)域撤回吧

soaeon@DESKTOP-FUJJTHR MINGW64 /f/gitstudy (master)
$ git reset HEAD   index.css

執(zhí)行g(shù)it status 查看一下是否退回來了

soaeon@DESKTOP-FUJJTHR MINGW64 /f/gitstudy (master)
$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

        new file:   index.js

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

        index.css

再比較一下工作區(qū)和暫存區(qū)的差別

soaeon@DESKTOP-FUJJTHR MINGW64 /f/gitstudy (master)
$ git diff --cached
diff --git a/index.js b/index.js
new file mode 100644
index 0000000..e69de29
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末型豁,一起剝皮案震驚了整個濱河市僵蛛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌迎变,老刑警劉巖充尉,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異衣形,居然都是意外死亡驼侠,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進(jìn)店門谆吴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來倒源,“玉大人,你說我怎么就攤上這事句狼∷癜荆” “怎么了?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵鲜锚,是天一觀的道長突诬。 經(jīng)常有香客問我,道長芜繁,這世上最難降的妖魔是什么旺隙? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮骏令,結(jié)果婚禮上蔬捷,老公的妹妹穿的比我還像新娘。我一直安慰自己榔袋,他們只是感情好周拐,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著凰兑,像睡著了一般妥粟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上吏够,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天勾给,我揣著相機(jī)與錄音滩报,去河邊找鬼。 笑死播急,一個胖子當(dāng)著我的面吹牛脓钾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播桩警,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼可训,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了捶枢?” 一聲冷哼從身側(cè)響起握截,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎柱蟀,沒想到半個月后川蒙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蚜厉,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡长已,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昼牛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片术瓮。...
    茶點(diǎn)故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖贰健,靈堂內(nèi)的尸體忽然破棺而出胞四,到底是詐尸還是另有隱情,我是刑警寧澤伶椿,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布辜伟,位于F島的核電站,受9級特大地震影響脊另,放射性物質(zhì)發(fā)生泄漏导狡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一偎痛、第九天 我趴在偏房一處隱蔽的房頂上張望旱捧。 院中可真熱鬧,春花似錦踩麦、人聲如沸枚赡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贫橙。三九已至,卻和暖如春反粥,著一層夾襖步出監(jiān)牢的瞬間卢肃,已是汗流浹背谓松。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留践剂,地道東北人鬼譬。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像逊脯,于是被迫代替她去往敵國和親优质。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評論 2 361

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

  • 概述 這次主要來講講Git的反悔操作军洼,自己平時(shí)在寫代碼的過程中經(jīng)常會出現(xiàn)想要棄用所有的改動或回滾到上一次commi...
    jumpingfrog0閱讀 19,776評論 1 12
  • 一巩螃、基本概念: 注:對于git的分布式概念及其優(yōu)點(diǎn),不重復(fù)說明匕争,自己百度或谷歌避乏。本文中涉及到指令前面有$的,在cm...
    大廠offer閱讀 1,431評論 0 3
  • 工作區(qū)和暫存區(qū) 工作區(qū) 在我們自己電腦中甘桑,里面有.git文件夾的那個目錄拍皮,我們一般叫做git工作區(qū),但是請注意.g...
    程序淡然閱讀 281評論 0 1
  • 一 Git配置和倉庫初始化 下面會介紹Git的使用,每個小節(jié)里會講解各個功能在命令行中的實(shí)現(xiàn)方式德谅,并在每小節(jié)的最后...
    Happioo閱讀 3,381評論 0 5
  • 1. GIT命令 git init在本地新建一個repo爹橱,進(jìn)入一個項(xiàng)目目錄,執(zhí)行g(shù)it init窄做,會初始化一個re...
    江邊一蓑煙閱讀 803評論 0 0