前言
年前在公司内部做了一次git原理分享,现在在这里分享其中核心部分之一:关于git add和commit命令的深入理解。我尽力用最浅显的文字和生动的图片让大家了解git原理,当然有不足之处还望大牛指点批评。
目录
1、理解几个概念:git仓库(版本库)、暂存区、HEAD、工作区
2、git add到底做了什么?
3、git commit到底做了什么?
1、理解几个概念:git仓库(版本库)、工作区、暂存区、HEAD
(1) git仓库(版本库):git仓库就是一个.git文件夹。这个文件夹内包含了很多文件(见插图2),其中有一个很重要的文件夹objects,保存了暂存区的所有文件对象,包括blob对象、tree对象、commit对象等,这些对象都是一以文件的形式来保存的。还有HEAD文件,保存着最新的提交的指针。当然很多人到这里可能还是不理解objects中的文件对象和HEAD中保存的指针到底是什么意思,没关系,下面会详细讲解。
(2)工作区:在一个项目目录中,除了.git文件的其他所有文件的集合就是工作区。
(3)暂存区:暂存区可以理解为文件从修改到最后提交到git版本库之间的一个缓存,为了防止一次提交了不必要的文件,有回退的余地,便有了暂存区。
(4)HEAD:HEAD在.git文件夹中是一个文件,文件的内容是一个32位的16进制数,这只是一个指针,他指向最近一个提交点、这个提交点实质是一个commit对象,对象里包含里多个属性,包括最后一个提交点目录结构索引、上一次提交点id、提交人、提交时间等。
2、git add到底做了什么?
(1) 首先,跟着我的思路,我们来创建一个git仓库, 通过一个例子来理解git add命令
1、首先,我们通过git init来创建一个仓库,这时会生成一个.git文件夹,这个文件夹就一个git仓库
2、创建一个文件A.java
执行 git add A.java
到.git里面的objects文件中,发现,多了一个文件夹,打开,里面有一个文件,名字是一串符号,打开这个文件,里面是一串无法识别的字符。
git add做了啥?
其实,在执行git add命令的时候,git首先会通过hash函数算出文件名A.java对应的sha-1值是1fed2a34f13dd2a34f13d,这个code是一个32位的16进制数,git会取这个code的前两位作为文件夹名在.git/objects文件夹中创建一个文件夹1f,取code的后30位作为文件名,在.git/objects/1f中创建一个文件ed2a34f13dd2a34f13d,git会将A.java的文件内容通过一定的压缩保存在这个文件中
未完待续.....
本文到这里就快结束了,文中可能有些地方没有说明清楚,欢迎指定讨论,有问题欢迎骚扰,看到会第一时间回复!