一、已经commit 但是还没有push
1、仅仅撤销commit ,保留add
git reset --soft HEAD^
//当我们执行 --soft 命令后,可以看到控制台无任何输出。它只是把HEAD指向了上一个版本。
2、仅仅撤销commit 并且也撤销add。(也就是删除工作空间的改动代码)
git reset --hard HEAD^
3、适用于在不小心在 master 分支上提交了代码,而实际想要在 aa 分支上提交代码的场景:
// 新检出一个新分支,但是仍在master 分支上,并不会切换到新分
git branch aa/update
// 恢复master本身提交的状态
git reset --hard origin/master
// 提交错的代码已经在新检出的分支上面了,可以继续进行开发或者
二、commit之后已经push到了远程
假设我们在A/develop分支上发现最后一次commit的功能是A/update分支的改动,如果想要撤销这次的commit,可以git revert 命令来撤销我们的操作。
// 撤销最近的一次提交
git revert HEAD --no-edit
git revert 是对给定的 commit 提交进行逆过程,该命令会引入一个新的提交来抵消给定提交的影响。 和 git cherry-pick 一样,revert命令不修改版本库的现存历史记录,相反它只会在记录添加新的提交。