对于开发人员来说,写完功能之后,都会提交到git上进行代码管理。如果我们提交了commit 之后想撤销该commit该如何操作呢?
工具/原料
git 工具
1、已经commit ,但没有push到远端
1
法1:仅仅撤销commit 保留add。 git reset --soft HEAD^ 当我们执行 --soft 命令后,可以看到控制台无任何输出。它只是把HEAD指向了上一个版本。
2
仅仅撤销commit 并且也撤销add。(也就是删除工作空间的改动代码) git reset --hard HEAD^
3
法2:适用于在不小心在 master 分支上提交了代码,而实际想要在 aa 分支上提交代码的场景: # 新检出一个新分支,但是仍在master 分支上,并不会切换到新分支 git branch aa/update # 恢复master本身提交的状态 git reset --hard origin/master # 提交错的代码已经在新检出的分支上面了,可以继续进行开发或者 push git checkout aa/update
2、Commit之后已经 push 到了远端
1
假设我们在A/develop分支上发现最后一次commit的功能是A/update分支的改动,如果想要撤销这次的commit,可以git revert 命令来撤销我们的操作。 # 撤销最近的一次提交 git revert HEAD --no-edit
2
git revert 是对给定的 commit 提交进行逆过程,该命令会引入一个新的提交来抵消给定提交的影响。 和 git cherry-pick 一样,revert命令不修改版本库的现存历史记录,相反它只会在记录添加新的提交。
3
但是如果只是commit注释写错了,只是想改一下注释:git commit --amend 此时会进入默认vim编辑器,修改注释完毕后保存就好了。
注意事项
git commit --hard 是具有破坏性,是很危险的操作,它很容易导致数据丢失
上一篇:git add后怎么撤销
下一篇:git分支覆盖另一个分支