首先我们先来向Git仓库中存储数据
//终端输入,其中 -w 参数就表示向Git仓库中写入
echo 'test content' | git hash-object -w --stdin
//输出
d670460b4b4aece5915caf5c68d12f560a9fe3e4
上面命令的功能是向Git仓库中存入 test content
,我们会看到输出了一串40位长度的内容,而且可以在 objects
目录下看到一个文件。
objects目录下的文件
这就是开始时 Git 存储内容的方式——一个文件对应一条内容,以该内容加上特定头部信息一起的 SHA-1 校验和为文件命名。校验和的前两个字符用于命名子目录,余下的 38 个字符则用作文件名。
然后我们看看这个文件的内容:
Git存储内容的形式
我们会发现这个文件里面并不是test content
,那这个文件内容怎么就变了呢?
test content
就变成上面图中的内容了//把内容取出来
git cat-file -p 70460b4b4aece5915caf5c68d12f560a9fe3e4
//输出
test content
上面我们演示的是直接同Git仓库操作数据,包括存数据取数据,而我们实际开发中,一般都是操作文件,对文件进行版本控制
下面我们来看看Git仓库是怎么对文件进行版本控制的
//我们先创建一个文件 test.txt ,内容为 version 1
echo 'version 1' > test.txt
上述命令我们就创建了一个内容为 version 1 , 文件名为 test.txt 的文件,这个时候如果我们用 git status
命令可以查看当前工程所有状态(开头说的3种状态)的文件信息,以及操作提示,这个是一个很有用的命令
直接用上面写入内容的方法向Git仓库中写入数据,也就是
//直接向Git中写入数据
git hash-object -w test.txt
//输出
83baae61804e65cc73a7201a7252750c76066a30
我们可以把内容取出来看看:
//取出刚刚存的内容
git cat-file -p 83baae61804e65cc73a7201a7252750c76066a30
//输出
version 1
这就是存储文件的过程
上述方式有什么问题?
怎么解决这些问题呢?这就需要Git中的第二个对象—— 树对象。下一次我们就来看看树对象。
如果对你有帮助,欢迎分享转发