多语言展示
当前在线:488今日阅读:19今日分享:20

git commit之后如何撤销?

对于开发人员来说,写完功能之后,都会提交到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 是具有破坏性,是很危险的操作,它很容易导致数据丢失

推荐信息