工作區(qū)和暫存區(qū)
??Git和其他版本控制系統(tǒng)如SVN的一個(gè)不同之處就是有暫存區(qū)的概念。先來(lái)看名詞解釋。
工作區(qū)(Working Directory)
??就是你在電腦里能看到的目錄传蹈,比如我的learngit文件夾就是一個(gè)工作區(qū)。
版本庫(kù)(Repository)
??工作區(qū)有一個(gè)隱藏目錄.git,這個(gè)不算工作區(qū)箫踩,而是Git的版本庫(kù)爱态。Git的版本庫(kù)里存了很多東西,其中最重要的就是稱為stage(或者叫index)的暫存區(qū)班套,還有Git為我們自動(dòng)創(chuàng)建的第一個(gè)分支master肢藐,以及指向master的一個(gè)指針叫HEAD。
分支和HEAD的概念我們以后再講吱韭。
??前面講了我們把文件往Git版本庫(kù)里添加的時(shí)候吆豹,是分兩步執(zhí)行的:
第一步是用git add把文件添加進(jìn)去,實(shí)際上就是把文件修改添加到暫存區(qū)理盆;
第二步是用git commit提交更改痘煤,實(shí)際上就是把暫存區(qū)的所有內(nèi)容提交到當(dāng)前分支。
??因?yàn)槲覀儎?chuàng)建Git版本庫(kù)時(shí)猿规,Git自動(dòng)為我們創(chuàng)建了唯一一個(gè)master分支衷快,所以,現(xiàn)在姨俩,git commit就是往master分支上提交更改蘸拔。
??你可以簡(jiǎn)單理解為,需要提交的文件修改通通放到暫存區(qū)环葵,然后调窍,一次性提交暫存區(qū)的所有修改。
??俗話說(shuō)张遭,實(shí)踐出真知〉巳現(xiàn)在,我們?cè)倬毩?xí)一遍菊卷,先對(duì)readme.txt做個(gè)修改缔恳,比如加上一行內(nèi)容:
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
然后,在工作區(qū)新增一個(gè)LICENSE文本文件(內(nèi)容隨便寫)洁闰。
先用git status查看一下狀態(tài):
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add..." to update what will be committed)
# (use "git checkout --..." to discard changes in working directory)
#
# modified: readme.txt
#
# Untracked files:
# (use "git add..." to include in what will be committed)
#
# LICENSE
no changes added to commit (use "git add" and/or "git commit -a")
??Git非常清楚地告訴我們歉甚,readme.txt被修改了,而LICENSE還從來(lái)沒有被添加過(guò)扑眉,所以它的狀態(tài)是Untracked(跟蹤)×迓現(xiàn)在,使用兩次命令git add襟雷,把readme.txt和LICENSE都添加后刃滓,用git status再查看一下:
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD..." to unstage)
#
# new file: LICENSE
# modified: readme.txt
#
現(xiàn)在,暫存區(qū)的狀態(tài)就變成這樣了:
??所以耸弄,git add命令實(shí)際上就是把要提交的所有修改放到暫存區(qū)(Stage)咧虎,然后,執(zhí)行g(shù)it commit就可以一次性把暫存區(qū)的所有修改提交到分支计呈。
$ git commit -m "understand how stage works"
[master 991811b] understand how stage works
2 files changed, 2 insertions(+)
create mode 100644 LICENSE
??一旦提交后砰诵,如果你又沒有對(duì)工作區(qū)做任何修改征唬,那么工作區(qū)就是“干凈”的:
$ git status
# On branch master
nothing to commit (working directory clean)
現(xiàn)在版本庫(kù)變成了這樣,暫存區(qū)就沒有任何內(nèi)容了: