一、已经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命令不修改版本库的现存历史记录,相反它只会在记录添加新的提交。

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐