导读:合并代码时,在解决冲突的时候不小心多删除了一点代码或者是发现提交的代码有错误,导致合并后的代码无法运行,一直报错,不得不进行代码回滚操作。
基本步骤:
1、cd+指定路径
2、git log
拿到你之前提交的历史,第一行的是一串40位的十六进制数字组成的commit id。
按q退出列表
3、git reset --hard HEAD(HEAD是指你需要的commit id,取前七位即可,例76f5161)
注意:这个是在你的代码未提交到远程仓库时操作的,因为reset会将你指定的HEAD后的所有commit删除,这样可能会造成新的代码丢失)
如果你的代码已经进行了远程提交,则进行下面的操作:
git checkout HEAD(HEAD是指你需要的commit id,取前七位即可,例76f5161)
4、这样代码就可以回退到指定的某次提交了(本地)
5、如果想继续将代码提交到远程,在提交过程中,有可能会出现pull失败,也无法push,提示是:
You are not currently on a branch, so I cannot use any 'branch <branchname>.merge' in your configuration file.
Please specify which remote branch you want to use on the command
line and try again (e.g. 'git pull <repository> <refspec>').
See git-pull(1) for details.
这是因为git checkout HEAD 是使HEAD头指针指向了一个具体的commit id,而不是一个分支,此时处于“分离头指针”模式,上面的提示告诉你“你不在任何分支上”,所以在添加新的提交时应创建一个新的分支
解决方法:
(1)git checkout -b temp (创建并切换temp分支)
(2)git checkout master (切换到你指定的分支上)
6、进行正常的代码远程提交操作
这样就完成了代码版本回退并正确提交的工作。