给出一个简单的存储库
$ touch empty ; git add empty ; git commit -m 'My commit' [master (root-commit) e9cc922] My commit 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 empty $ git tag -a -m 'My tag' mytag
我们注意到其中一件事与其他事情不同,下面重点介绍。为什么树对象直接将SHA-1哈希值编码为20个无符号字节的序列,而提交和标记将它们编码为40个ASCII十六进制数字?
我在调查answer to a related question about git internal storage时注意到了这种差异。
$ for f in .git/objects/??/* ; do echo $f ; openssl zlib -d < "$f" | xxd ; echo ; done .git/objects/41/7c01c8795a35b8e835113a85a5c0c1c77f67fb 00000000: 7472 6565 2033 3300 3130 3036 3434 2065 tree 33.100644 e 00000010: 6d70 7479 00e6 9de2 9bb2 d1d6 434b 8b29 mpty........CK.) 00000020: ae77 5ad8 c2e4 8c53 91 .wZ....S. .git/objects/da/867754dac38858c708292f49de41b7eff6f5d7 00000000: 7461 6720 3133 3400 6f62 6a65 6374 2065 tag 134.object e 00000010: 3963 6339 3232 3632 6561 3734 3138 3864 9cc92262ea74188d 00000020: 6530 3436 6563 6166 3265 3363 3063 3061 e046ecaf2e3c0c0a 00000030: 3436 3966 3734 320a 7479 7065 2063 6f6d 469f742.type com 00000040: 6d69 740a 7461 6720 6d79 7461 670a 7461 mit.tag mytag.ta 00000050: 6767 6572 2047 7265 6720 4261 636f 6e20 gger Greg Bacon 00000060: 3c67 6261 636f 6e40 666f 6f2e 696e 7661 <gbacon@foo.inva 00000070: 6c69 643e 2031 3435 3737 3035 3338 3820 lid> 1457705388 00000080: 2d30 3630 300a 0a4d 7920 7461 670a -0600..My tag. .git/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 00000000: 626c 6f62 2030 00 blob 0. .git/objects/e9/cc92262ea74188de046ecaf2e3c0c0a469f742 00000000: 636f 6d6d 6974 2031 3732 0074 7265 6520 commit 172.tree 00000010: 3431 3763 3031 6338 3739 3561 3335 6238 417c01c8795a35b8 00000020: 6538 3335 3131 3361 3835 6135 6330 6331 e835113a85a5c0c1 00000030: 6337 3766 3637 6662 0a61 7574 686f 7220 c77f67fb.author 00000040: 4772 6567 2042 6163 6f6e 203c 6762 6163 Greg Bacon <gbac 00000050: 6f6e 4066 6f6f 2e69 6e76 616c 6964 3e20 on@foo.invalid> 00000060: 3134 3537 3730 3531 3736 202d 3036 3030 1457705176 -0600 00000070: 0a63 6f6d 6d69 7474 6572 2047 7265 6720 .committer Greg 00000080: 4261 636f 6e20 3c67 6261 636f 6e40 666f Bacon <gbacon@fo 00000090: 6f2e 696e 7661 6c69 643e 2031 3435 3737 o.invalid> 14577 000000a0: 3035 3137 3620 2d30 3630 300a 0a4d 7920 05176 -0600..My 000000b0: 636f 6d6d 6974 0a commit.
答案 0 :(得分:0)
在问题的comment Philip Oakley中提到了在git邮件列表中找到的内容,但遗憾的是没有进一步阐述。
我发现浏览邮件列表的所有内容为these两个threads Jakub Narębski asks(2011)
Linus在想什么?!?
和tells(2013)他
[...]总是想知道为什么这是SHA-1所在的唯一对象格式 20字节二进制格式而不是40字符十六进制字符串格式
但没有得到任何反应/回应。
我也很想知道邮件列表上是否还有其他帖子,是否确实存在某种解释,或者Philip Oakley是否也只考虑其中一个主题(或另一个没有解释)。< / p>
由于我提到的第一个帖子(从2011年开始)实际上最初是关于“git cat-file -p
不一致”而菲利普奥克利也提到了他认为“与git cat- *命令相关”的线程我想这可能是他记得的那个。 :/
(这并没有真正回答这个问题,但至少表明这种不一致甚至让git core devs感到困惑。因为我是新用户,所以我不能将其作为评论发布)