Git 中的 HEAD

1、Git HEAD 存放位置

HEAD 指的就是 .git/HEAD 文件,它存储着当前分支的名字,我们可以打这个文件看一看:

java 复制代码
ref: refs/heads/master

由此,我们可以得知当前所处于 master 分支。

如果我们继续往下走:打开 refs/heads/master 文件,一串密码映入眼帘:

java 复制代码
7e136f508b982790db5686482075c60ee3ee4fed

这是master分支上最新提交的commit id。

其实,我们可以看下面的这张示意图,对于header的理解将会一目了然:

2、Git HEAD 的作用

2.1、Git HEAD 的作用一:显示当前所出于哪个分支

我们查看git提交日志的时候,会经常碰到head,如下所示:

java 复制代码
$ git log
commit c4f9d71863ab78cfca754c78e9f0f2bf66a2bd77 (HEAD -> master)

如上所示,HEAD -> master 告诉我们当前处于 master 分支。

2.2、Git HEAD 的作用二:指代当前分支的最新提交的commit id

有时候,我们commit提交代码后,发现这一次commit的内容是有错误的,面对这种情况有两种解决方法:

java 复制代码
解决方法1:修改错误内容,再次commit一次

解决方法2:使用git reset命令撤销这一次错误的commit

此时,该head出场了,它常常与reset连用,如下所示:

java 复制代码
$ git reset HEAD <file>

等价于:

java 复制代码
$ git reset commit_id_latest <file>   //commit_id_latest 需替换为实际的最新的commit it 

因为head表示当前分支的最新提交的commit id,上述命令的目的是将文件file恢复到指定的commit id。

此外,我们查看最近一次提交的改动内容,可以通过:

java 复制代码
git diff  HEAD^ HEAD

HEAD^表示倒数第一次提交,即最近一次提交

HEAD^表示倒数第二次提交

HEAD^^表示倒数第三次提交

相关推荐
恋喵大鲤鱼1 小时前
git rebase
git·git rebase
大志哥1236 小时前
idea+git插件+云备份实现项目新分支新建维护
git
恋喵大鲤鱼6 小时前
git merge
git·git merge
码客日记7 小时前
Spring Boot 配置文件敏感信息加密(Jasypt 企业级完整方案)
java·spring boot·git
_codemonster7 小时前
Codex 核心进阶玩法(技能/MCP/派生/分叉/Git/钩子/子智能体)
git
逻极7 小时前
Git 从入门到精通:版本控制协作实战指南
git·github·分支管理·版本控制
恋喵大鲤鱼7 小时前
git clean
git·git clean
Patrick_Wilson8 小时前
为省一次回归测试,该不该把多个改动堆进一条分支?
git·ci/cd·架构
恋喵大鲤鱼8 小时前
git blame
git·git blame
yeflx8 小时前
Git操作
git