What is the HEAD in Git?

Technology CommunityCategory: GitWhat is the HEAD in Git?
VietMX Staff asked 3 years ago

HEAD is a ref (reference) to the currently checked out commit.

In normal states, it’s actually a symbolic ref to the branch you have checked out – if you look at the contents of .git/HEAD you’ll see something like “ref: refs/heads/master”. The branch itself is a reference to the commit at the tip of the branch. Therefore, in the normal state, HEAD effectively refers to the commit at the tip of the current branch.

It’s also possible to have a detached HEAD. This happens when you check out something besides a (local) branch, like a remote branch, a specific commit, or a tag. The most common place to see this is during an interactive rebase, when you choose to edit a commit. In detached HEAD state, your HEAD is a direct reference to a commit – the contents of .git/HEAD will be a SHA1 hash.

Generally speaking, HEAD is just a convenient name to mean “what you have checked out” and you don’t really have to worry much about it. Just be aware of what you have checked out, and remember that you probably don’t want to commit if you’re not on a branch (detached HEAD state) unless you know what you’re doing (e.g. are in an interactive rebase).