情形1:只是想修改提交说明,或者解决冲突
git commit --amend
如果此时存在 Change-Id
字段,也要记得删除这条字段所在的整行内容,再保存修改。
情形2:撤销误暂存(commit)的文件
git reset HEAD SomeFileName
情形3:恢复文件成最近提交的状态
git checkout -- SomeFileName
注意:这个操作比较危险,可能会删掉未暂存的修改
情形4:如果 git commit 之后发现了错误或者其他不应该进行 commit 的情况
- 先使用 git log 查看日志,并确定你想要返回的 commit 的节点:
commit cad761e9f193336ce78fe49e257bc21d9b9ce1a3
Author:
Date:
some message
commit f93aaf2c5e920c45532dd37ca69ef509461e38b0
Author:
Date:
- 执行 git reset commit_id 命令,撤销 commit 操作。
例如:
git reset f93aaf2c5e920c45532dd37ca69ef509461e38b0
会使我们的 commit 操作撤销,但是我们本次 commit 的代码修改其实是还在的。
如果,我们撤销 commit 时,也不想保留本次的代码修改的话,可以为 reset 加上 --hard 参数:
git reset --hard commit_id
这样操作之后,我们本次的代码修改也会被重置,因此,需要我们仔细权衡使用哪种方式。