Git 工作區和暫存區

2021-09-29 06:31:15 字數 2341 閱讀 5268

git和其他版本控制系統如svn的乙個不同之處就是有暫存區的概念。

暫存區(stage)是git非常重要的概念,弄明白了暫存區,就弄明白了git的很多操作到底幹了什麼。

是你在電腦裡能看到的目錄,比如我的learngit資料夾就是乙個工作區

工作區有乙個隱藏目錄.git,這個不算工作區,而是git的版本庫。

git的版本庫里存了很多東西,其中最重要的就是稱為stage(或者叫index)的暫存區,還有git為我們自動建立的第乙個分支master,以及指向master的乙個指標叫head

將檔案提交到倉庫包括兩個步驟,add 和commit 

第一步是用git add把檔案新增進去,實際上就是把檔案修改新增到暫存區;

第二步是用git commit提交更改,實際上就是把暫存區的所有內容提交到當前分支。這個分支因為我們建立git版本庫時,git自動為我們建立了唯一乙個master分支,所以,現在,git commit就是往master分支上提交更改。

你可以簡單理解為,需要提交的檔案修改通通放到暫存區,然後,一次性提交暫存區的所有修改。

修改readme.txt,然後在新建乙個license(執照)文字檔案

先用git status檢視一下狀態:

λ 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:#tracker:***

(use "git add ..." to include in what will be committed)

lecense

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

git非常清楚地告訴我們,readme.txt被修改了,而license還從來沒有被新增過,所以它的狀態是untracked

現在,使用兩次命令git add,把readme.txtlicense都新增後,用git status再檢視一下:

所以,git add命令實際上就是把要提交的所有修改放到暫存區(stage),然後,執行git commit就可以一次性把暫存區的所有修改提交到分支。

λ git commit -m"理解stage怎麼工作的"

[master 2561b39] 理解stage怎麼工作的

2 files changed, 3 insertions(+), 1 deletion(-)

create mode 100644 lecense

一旦提交後,如果你又沒有對工作區做任何修改,那麼工作區就是「乾淨」的

git工作區和暫存區

git和其他版本控制系統如svn的乙個不同之處就是有暫存區的概念。先來看名詞解釋。工作區 working directory 就是你在電腦裡能看到的目錄,比如我的learngit資料夾就是乙個工作區 版本庫 repository 工作區有乙個隱藏目錄.git,這個不算工作區,而是git的版本庫。gi...

Git 工作區和暫存區

工作區 電腦裡能看到的目錄就是工作區 版本庫 工作區有乙個隱藏目錄.git,這個不算工作區,而是git的版本庫 git的版本庫里存了很多東西,其中最重要的就是稱為stage的暫存區,還有git為我們自動建立的第乙個分支master,以及指向master的乙個指標叫head。把檔案往git版本庫里新增...

git基礎 工作區和暫存區

git和其他版本控制系統如svn的乙個不同之處就是暫存區的概念 工作區 就是電腦上能看到的目錄,可以理解為當前倉庫所在的目錄比如htdocs下的git資料夾 不過不準確 版本庫 工作區下面有乙個隱藏的目錄.git 這個就是我們的版本庫 git的版本庫里存了很多東西,其中最重要的就是稱為stage 或...