获取或者创建本地Git仓库这篇文章使用了gitsample作为示例介绍了如何从Git服务器获取本地仓库。本文将继续使用这个项目作为示例。
本文将介绍下列命令的常见用法:
git add
git status
git diff
git commit
1. Git本地仓库的结构
1.1. 本地仓库的组成
一个典型的Git仓库是由工作区(Working Tree,之前也被称之为Working directory)、暂存区和版本库(Repository)组成的。下图是一个典型的Git仓库结构图:
以gitsample仓库为例,它的文件夹目录文件树结构如下所示:
gitsample
└─.git
│ └─...
│ └─objects
│ ├─index
│ ├─HEAD
└─workspace
│ ├─index.php
├─demo_status.txt
├─README.md
工作区
顾名思义,我们的工作文件都存放在这个区域。gitsample目录下面所有的用户目录和文件都属于工作区内容;
暂存区
在早前git版本也被称为缓存区,暂存区的内容就是预期的下一次的提交,也就是提交时需要git写入到版本库的内容。将文件添加到暂存区的动作可以简单的理解为另存了文件的快照,也就是git复制了当前文件的内容然后粘贴到暂存区保存为副本。.git文件夹内有一个名为index的文件,此文件就是暂存区文件的索引(索引指向的文件的快照是存放在objects目录的)。可以使用git ls-files
命令查看暂存区的文件列表;
版本库
存放的是版本历史。每次提交都会产生一个新的版本,最近一次版本的commit id(SHA-1哈希值)存放在HEAD文件中。沿着最近一次的版本可以一直向前追溯到初始的版本。
1.2. 工作区文件的生命周期
在Git中,工作区的文件状态是有生命周期变化的。如下图所示:
1). 在项目工作区新建的文件,其状态为Untracked(未追踪);
2). 对于状态处于1)或4)的文件,将其添加到暂存区后其状态变为Staged(已暂存,等待提交);
3). 对于状态处于2)的文件, 将其提交到版本库后其状态变为Unmodified(亦即已提交);
4). 当文件被修改后其状态变为Modified(已修改)。
2. git add 向暂存区添加文件的快照
假如工作区新建了一个add_demo.txt文件,此时使用下面的方式将文件添加到暂存区:
git add add_demo.txt
:只将add_demo.txt文件的快照添加到暂存区
git add *.txt
:将所有txt文件快照添加到暂存区
git add .
:将所有文件的快照添加到暂存区
3. git status 查看工作区和暂存区、暂存区和版本库的文件状态变化
新建add_demo.txt文件尚未添加到暂存区时:
$ git status
On branch master
Your branch is up to date with 'origin/master'.
Untracked files:
(use "git add <file>..." to include in what will be committed)
add_demo.txt
nothing added to commit but untracked files present (use "git add" to track)
可以看到git检测到工作目录中有未追踪的文件。接下来执行git add .
命令将文件添加到暂存区后再来查看状态:
$ git status
On branch master
Your branch is up to date with 'origin/master'.
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
new file: add_demo.txt
从命令的执行结果可以看到文件现在已经是等待提交状态了。
4. git diff 比较文本内容差异
git diff
:比较工作区的文件和暂存区文件的差异。git diff只会比较已经暂存过的文件。例如,我们在工作区新增add_demo.txt文件并在文件中保存一段文字“this is a demo file for file staging.”,此时使用git diff命令是不会比较这个文件的;当此文件添加到暂存区后,我们再来修改这个文件在里面新加一行文字“Git diff should work and show the difference this time.”并保存,再使用git diff来比较就可以看到暂存区和工作区的文件内容差异了:
$ git diff
diff --git a/add_demo.txt b/add_demo.txt
index fe17f7f..df7cefe 100644
--- a/add_demo.txt
+++ b/add_demo.txt
@@ -1 +1,2 @@
-this is a demo file for file staging.
\ No newline at end of file
+this is a demo file for file staging.
+Git diff should work and show the difference this time.
\ No newline at end of file
git diff --staged
:比较暂存区的文件和最近一次提交版本的差异。此命令不会比较被添加到暂存区但从未被提交到版本库的文件。
git diff --stat
:显示差异的简要统计信息。例如:
$ git diff --stat
add_demo.txt | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
5. git commit 将暂存区的内容提交到版本库
git commit -m "message"
命令会将暂存区内的所有文件提交到版本库,并且git会为此次提交生成一个commit id。这个commit id是一个40位长度SHA-1哈希值,用于全球唯一标识一次提交。
$ git commit -m "add_demo.txt"
[master e435501] add_demo.txt
1 file changed, 3 insertions(+)
create mode 100644 add_demo.txt
提交命令运行结果中有一段“[master e435501] add_demo.txt”,其中e435501
就是这次提交的commit id前7位,又被称为短commit id。一般来说前7位就足以全局表示一次提交了。