HEAD 是一个指针,通常情况下,它指向当前所在分支,而分支又指向一个 commit 提交。HEAD 并不总指向一个分支,某些时候仅指向某个 commit 提交,这就形成 detached HEAD。
切换到 detached HEAD 状态时,会有一个警告。
提示我们可以任意的修改和提交,通过切换回分支时不影响任何分支的状态。
在你没切走之前,可以创建一个新分支来保留所创建的提交,则可以通过在 switch 命令中使用 -c 来执行此操作:
git switch -c <new branch name>
如果你没有执行上面的命令,当你切走之后,会有一个警告。
在 detached HEAD 状态下开发新的 feature,将没有任何办法引用到这个 feature。你可以把 detached HEAD 状态看作是正在一个未命名的分支上。你只需要给这个分支命名就可以使用这个 feature 了,然后就可以把这个新分支上的代码合并到其他分支上了,通过命令:
git branch <new-branch-name> 588f5c0
假设你正在进行一次疯狂的重构,但现在你不确定是否要继续下去。这时你想要看一下开始这次重构之前项目原来的样子,首先你需要查看版本的ID,然后使用 git checkout 切换到这个之前的版本。
git checkout a1e8fb5
这让你的工作区切换到了 a1e8fb5 comimit 的状态。你可以查看文件、编译项目、运行测试用例,甚至编辑文件,完全不用担心丢失项目“当前”的状态,你在这里做的所有修改都不会被保存到项目中。当你想要继续那次疯狂的重构时,你需要回到项目的“当前”状态。
git checkout master
git的reset和checkout的区别
git的reset和checkout的区别:https://blog.csdn.net/q563573095/article/details/79567430