git - git status 在内部是如何工作的?

标签 git

来自git object model ,文件和文件夹通过它们的 sha1 哈希保存到 .git 文件夹中的位置。

git 如何在内部知道文件是否已被删除、添加或编辑(具体来说,它如何计算您在键入 git status 时看到的更改)?系统是否仅从 sha1 确定此信息?

最佳答案

答案有点太长,需要一段时间才能写出来,所以这里是摘要。

简短的回答是 git 使用 SHA-1 来检查跟踪更改,但文件名存储在其他地方。


内容存储在 pack (*1- 阅读下文) 而名称存储在 idx 中。
当你运行 git status 时,git 检查 idx 文件(元数据)中是否已经有这个路径,并根据结果决定它是否是一个新文件。

如果不是新文件,git 比较 SHA-1 来跟踪变化。


为什么我必须使用 git mv 来移动文件而不是简单的 mv?

当您执行 git status 时,git 会搜索您的工作目录,以查找 idx 文件中的 “已注册” 路径与您的工作目录之间的匹配项。

当您使用mv 移动文件时,您的工作目录没有 git 存储的“原始”路径,并且由于 git 无法再找到“已注册”路径,因此该文件被标记为如已删除。

但是同时 git 看到一个新文件,您刚刚将文件移动到的路径,所以文件将被标记为新文件。

另一方面,当使用 git mv 时,git 会更新元数据以指向新名称,并且内容将被标记为 rename。在这种情况下,git 会更新 idx 文件中文件的注册路径。
如果您移动和更新,它也会被标记为重命名 + 修改。

enter image description here enter image description here


如何找出文件的 SHA-1 值?

使用 git ls-tree 内部命令找出文件的 SHA-1。

enter image description here


注意

当您将内容添加到暂存区时,Git 开始跟踪内容。
添加文件后,git 将以下信息存储在文件中

[blob][1 white space][content length][null][content]

If you have a file with the string `hello` it will look like this:
blob 5\0Hello

现在 git 计算这个文件的 SHA-1(使用 sha1sumn)用 z-lib 压缩它并用这个 SHA-1 保存文件作为 `.git/objects' 的名字.

当 git 打包存储库时,它将进入打包文件。

如何查看文件内容?

由于文件是用 z-lib 压缩的,我们有几个选项来获取内容:

  • 第一个选项是查看存储在文件中的压缩包
  • 其次是查看解压后的内容(如上所述)
  • 仅查看文件内容,不包含任何 git 元数据。

enter image description here

并且为了表明 git 实际上使用了上面描述的内容,这里与 git 在幕后执行的计算 SHA-1 的命令相同

enter image description here


这是提交的说明以及它如何处理文件名。

( http://shafiulazam.com/gitbook/1_the_git_object_model.html ) enter image description here

关于git - git status 在内部是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36922197/

相关文章:

git - 子分支和父分支同步自己

linux - 在 .gitconfig 中 stash GitHub token

git - 在 git log 的 --name-status list 中,状态标签后缀的数字是什么?

git - 如何将文件夹中的所有内容添加到我的 GitHub Repo

git - 让 git "assume-unchanged"成为每个人的文件,而不仅仅是在本地

git - SourceTree 非常慢,有很多存储库

Git 从 future 的提交中删除文件但保留以前的版本

git - 从 git 存储库中删除无关的提交

git - 如何用 Git 将一个分支一分为二?

git - 如何解决 GitLab 上的冲突?