暂存区
从 gi t的角度来看,文件的修改涉及到以下三个区域:工作目录, stage区(暂存区)以及本地仓库.
当我们对我们的项目做了一些修改(新增文件,删除文件,修改文件等),我们处理的就是我们的工作目录.这个目录是存在于我们电脑的文件系统上的.所有的修改都会保留在工作目录直到我们把它们加入到暂存区(通过git add命令)。
暂存区这是对下一次提交最好的表示方式,当我们执行git commit
,git会获取暂存区中的修改,并将这些修改作为下一次的提交内容.暂存区的一个实际作用就是允许你调整你的提交,你可以向暂存区新增和删除修改直到你对你下一次的提交满意,这个时候你就可以用git commit
提交你的内容了。
在提交修改后,它们就会进入.git/objects
目录,在其中被保存为commit,blob以及tree objects(参考[数据模型]https://www.jianshu.com/p/843c8b0aa007)那一篇文章)
把暂存区认为是一个存储修改的真实区域并不准确,git没有专门的stage目录来存放这些文件的修改(blobs),git有一个名为index的文件来跟踪这三个区域的修改:工作目录,暂存区以及本地仓库。
当我们添加修改到暂存区的时候,git会更新index文件中的信息,并且创建一个新的blob object,然后将它们放到与之前提交的记录所产生的其他blob相同的.git/objects目录中。
index的变化
接下来我们就通过一个正常的git流程来演示下git如何使用的index
首先在我们的仓库里面有master以及feature两个分支,如果我们执行下面的命令,会有三件事情发生
gi