一. 引言
什么是Git引用和分支?比如我在 Github 上一个项目的 .git/refs
目录下:
├─heads
│ dev
│ master
│
├─remotes
│ └─origin
│ master
│
└─tags
refs 目录下包含了 heads、remote、tags 三个子目录,每个子目录下都有对应的文件
打开 heads/master
文件,查看其内容:
$ cat heads/master
1b41db435c03fe80fa965dc77442261708deb16d
上述这段编码,其实就是 SHA-1 值,再来看看其类型和内容:
$ git cat-file -p 1b41d
tree 03073e441d5360400b758257647c2a0250ee38c7
parent 90157be126d9204779c63aaadf3a95f5fa207fc4
author haohuin <huins..[email protected]> 1623935829 +0800
committer haohuin <huins..[email protected]> 1623935829 +0800
系统介绍Readme
这个 SHA-1 值就指向 Git 仓库中的某个提交对象 ID。既然能用 SHA-1 值来区分不同的提交对象,为何要创建一个存放 SHA-1 值的文件呢?因为 SHA-1 值过于长,而且没有规律,如果利用简单的文件名来引用对原来的提交对象,就不用记住复杂且无规律的 SHA-1 值了。
因此在 Git 中,像这种只含有 SHA-1 值的文件,就是 Git 的引用(Reference)。而分支,就是一个指向某一系列提交之首的指针或引用。如下图所示:
下面就讲解一下 Git 中的引用和分支的具体内容
二. Git引用
在引言中提到过,Git 引用内部存储着 SHA-1 值,来跟踪和引用不同的 Git 对象,从类型上讲,可以分成 HEAD 引用,分支引用(branch),标签引用(tag)和远程引用(remote):
2.1. HEAD引用
在 .git
根目录中,有一个 HEAD 文件,我们先来查看一下 HEAD 文件中的内容:
$ cat .git/HEAD
ref: refs/heads/master
发现 HEAD 中的内容指向了一个引用 refs.heads/master
,当执行 git checkout dev
,将当前版本切换至 dev 分支后,HEAD 文件内容会变成如下引用值:
$ git checkout dev
Switched to branch 'dev'
$ cat .git/HEAD