两种方式:
方式一:git reset (回退)
方式二:git revert (反做)
区别:
方式一撤销后不显示已撤销的提交记录,本质是移动了branch的head指针。
方式二撤销后还显示已撤销的提交记录,本质是生成一次新提交覆盖掉错误的提交。
推荐使用第一种:
-
回退提交:git reset --hard <version>
示例:git reset --hard HEAD~1
或git reset --hard 79ce81274bede9bac
。
此命令等价于在idea里点击:
请谨慎使用 --hard参数,详解见下文。如果已commit未push,则已搞定。如果已push,则继续执行步骤2。
-
强制push:git push -f 。
因为此时版本号会比远程的低,git push会失败,所以强制。
至此,回退完成。下面是reset命令详解:
HEAD:
HEAD是指当前的快照,主要配合reset
的
--hard
,--mixed
和--solf
三个参数对对本次的修改进行处理。
HEAD~1
指回退一个快照,可以简写为HEAD~
HEAD~2
指回退两个快照。
HEAD^
主要是控制merge之后回退的方向。
HEAD~
才是回退的步数。