Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master
,以及指向master
的一个指针叫HEAD
。
分支和HEAD
的概念我们以后再讲。
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用git add
把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit
提交更改,实际上就是把暂存区的所有内容提交到当前分支。
因为我们创建Git版本库时,Git自动为我们创建了唯一一个master
分支,所以,现在,git commit
就是往master
分支上提交更改,注意,这里只是提交到本地仓库,需要再用git push命令提交到远程仓库。
你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。从《时间机穿梭——版本回退》中可以看到,新增的还没加进版本库的文件属于Untracked files,修改的文件还没加到缓存区的属于Changes not staged for commit,已加到缓存区的文件属于Changes to be committed。