注意看上图的HEAD,这就是指针,当前指针指向dev分支,最新的一次提交是git commit -m ‘3’,备注信息是“3”
版本切换
git reset --hard HEAD
切换到HEAD指针指向的版本
怎么理解:比如在执行git commit -m '3’之后,你又在index.css中添加了body{background:red},然后执行一下git reset --hard HEAD,那么body{background:red}这行代码就不见了,工作区当前的代码回到了最后一次commit的地方,也就是回到了git commit -m '3’这个时候的状态
git reset --hard HEAD^
回退到上一commit版本,可以一直回退
git reset --hard HEAD~3
回退3个版本
额外的,无论你现在的work tree是否为clean,回退3个版本都是可以从3回退到ad(3也就是HEAD为当前版本)
git reset --hard 4d8836c06b
回退到4d8836c06b版本
git reset --hard c501d1a461
当然,也可以前进到c501d1a461版本(c501d1a461或者c501d1a都可以,位数随便都行)
但是,回退版本后想要提交代码老是提示要先pull,然而pull后代码又是最新的(也就是说,我要将4d8836c06b push上去之前必须被要求先pull,而pull下来版本又跳到c501d1a461),这样达不到回退版本的目的,怎么办?以下妙招:
执行git push origin HEAD --force或者git push -f,其中-f就是force,强制的意思
想理解更多git的实战命令,欢迎留言,带你解决更多实际问题