git status
git warning: refname 'HEAD' is ambiguous
git warning: refname 'HEAD' is ambiguous
On branch develop
Your branch is up-to-date with 'origin/develop'
nothing to commit, working tree clean
ref信息如下
git show-ref
...... refs/heads/HEAD
...... refs/heads/develop
...... refs/heads/master
...... refs/remotes/origin/HEAD
...... refs/remotes/origin/develop
...... refs/remotes/origin/master
...... refs/tags/v1.0
...... refs/tags/v1.1
应该怎么解决?
这个问题是因为你有一个叫做
HEAD
的分支造成的,这个名字你可以看作是一个保留字,它用于标示哪个分支是 当前分支 ,而不应该直接拿来做分支的名字(但是 remote 的HEAD
分支是 OK 的,比如 origin/HEAD,经常有人把这个 checkout 下来,结果就变成了本地的HEAD
分支,这就是此问题产生的源头)。解决的方法很简单,删除或者更名这个分支就可以了,比如说删除:
git branch -D HEAD
另外,也有人用
HEAD
创建了一个 tag,这也会引起相同的问题,附记。