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