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^^表示倒数第三次提交

相关推荐
C137的本贾尼6 小时前
Git基本操作(四):删除文件
git
C137的本贾尼7 小时前
撤销修改:三种场景下的“反悔”操作
git
C116117 小时前
antdesign使用git命令clone仓库后,找不到CLAUDE.md 文件什么原因
git
BoomHe10 小时前
git Rebase 为任意一笔提交补上 Change-Id
android·git·android studio
OsDepK11 小时前
AudioSplit音频多轨免费分离工具即将发布
ide·git·python·音视频·集成学习
jiayong2311 小时前
Git 常见错误与详细解决方案
大数据·git·elasticsearch
jiayong2312 小时前
Git 分支命名、区别、联系与顺序关系说明
大数据·git·elasticsearch
无风听海12 小时前
Git 对象存储模型深度解析
git
展翅飞翔的小王12 小时前
速查】Git 常用提交流程 + 强制用远端覆盖本地
git
C137的本贾尼13 小时前
分支管理(一):创建、切换与合并,体验“平行宇宙”
git