操作文件

获取或者创建本地Git仓库这篇文章使用了gitsample作为示例介绍了如何从Git服务器获取本地仓库。本文将继续使用这个项目作为示例。
本文将介绍下列命令的常见用法:

git add
git status
git diff
git commit

1. Git本地仓库的结构

1.1. 本地仓库的组成

一个典型的Git仓库是由工作区(Working Tree,之前也被称之为Working directory)、暂存区和版本库(Repository)组成的。下图是一个典型的Git仓库结构图:


图-1 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 ..." 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 ..." 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位就足以全局表示一次提交了。

你可能感兴趣的:(操作文件)