三者之间的联系,我本人结合网上的一些经验总结如下,如图1所示:
图 1
我们打开 项目文件夹,整个项目就是我们的工作区(如图2所示):
图 2
版本库在哪里呢?就是这个".git"(如图3所示):
图 3
打开".git"文件夹之后(如图4所示):
图 4
图中画圈的的两个,一个index对应的是暂存区的目录树,包含了文件名和文件的状态信息,但是文件的内容并不存在放此处,而是存放在"objects"文件夹里;head对应的是版本库的目录树,也包含了文件名和文件的状态信息,同样的文件的内容也是保存在"objects"文件夹里。
当我们运行"git add"命令的时候,本地项目中所做的的修改会首先提交到暂存区里,这个时候暂存区的目录树被更新,产生一个ID,这个ID对应着修改的文件内容(就好比酒店的房间和房卡的联系),修改的文件内容是保存在"objects"文件夹里
当我们运行"git commit"命令的号死后,暂存区的目录树会传送给工作区,保存在"HEAD"文件里面,此时这个这个目录树对应的文件还是刚才已经提交到"objects"文件夹里的内容
大致的流程如下(如图5和图6):
图 5
图 6