Git之分区介绍

一般来说,Git有三个分区,分别是工作区、暂存区和版本库,而暂存区则是Git与其他版本控制系统不同的原因。

工作区(Working Dircetory)

就是我们在自己电脑里能够看到的目录,即我们之前创建的gitRepository目录文件夹其实就是工作区。

版本库(Repository)

我们创建的工作区中其实有一个隐藏的.git目录,虽然在工作区中,但是并不算工作区,它其实就是Git的版本库。Git的版本库里存了很多东西,其中最重要的就是称为stage或index的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针HEAD。

Git之分区介绍_第1张图片

之前我们说过添加并提交文件到版本库的过程大致可分为两步,即add和commit,其实现在结合Git的分区来说的话,git add命令其实就是把工作区的文件添加到了暂存区而已,而之后的git commit命令才是把暂存区的文件提交到当前分支上的操作。

我们现在再写一个文件,验证一下这个添加并提交文件的过程是否如我们分析的这样。假设我们现在有另一个文件test.xml在工作区,文件内容为:

Git之分区介绍_第2张图片

然后,我们再把之前的demo.txt加以修改,修改内容如下:

Git之分区介绍_第3张图片

之后我们使用git status命令查看一下当前版本库的状态:

 

可以看到,Git已经很清楚的告诉了我们demo.txt文件被修改了,而test.txt文件之前从未出现过,目前也还没有被添加和提交,所以状态显示Untracked。然后,我们使用git add命令分两次将这两个文件添加到暂存区:

 

此时,再使用git status命令查看当前版本库状态:

 

如上所示,现在的暂存区的状态就变成了这样:

Git之分区介绍_第4张图片

 所以,git add命令实际上就是把工作区的文件添加到暂存区。然后我们使用git commit命令提交文件:

 

提交之后再查看一下版本库的状态:

 

如果提交之后我们没有对工作区进行任何修改,那么此时工作区就是干净的。而此时的暂存区的状态是这样的:

Git之分区介绍_第5张图片

你可能感兴趣的:(Git,工作区,暂存区,版本库)