Git 如何撤销最新一次Commit

在使用git时,经常会遇到在未push之前,发现提交的代码或者comment有问题。如果在Agile 敏捷开发的公司,往往你的git与Jira是相关联的,这时一般要求你的comment 里的Story Id要与Jira 一致,如果写错了,导致你的commit会push不到远程服务器上。这只是我提到的一种情况,国内的公司往往这种模式还很少。我们就是在任何commit有问题想回撤一下这个commit。

现在我做准备提交一个文件到github上,文件名叫ReadMe.md

git add ReadMe.md
git commit -m "this is a wrong commit"

这个commit 的comment是错误的,将它修改为“this is a right commit”

git commit --amend

这时会在git bash的命令行里,出现vi 编辑窗口,然后进行修改保存就可以了,因为使用的是vi,请掌握vi的编辑保存操作。

amend窗口

以上是在没有代码要撤销,只有comment里的信息要修改时,所使用的命令

如果你的上一次提交,还有代码改错了,要撤回重新修改,那可以使用下面的命令

git reset HEAD~
<< edit files as necessary >>                            
git add ... 
git commit -c ORIG_HEAD 

这个命令会回滚你的全部commit,你只需重新编辑你的文件,然后重新git add, commit

ORIG_HEAD的意思是和“--amend”是一个意思,会打开一个编辑器,去编辑你的comment,修改完保存即可 如果你的comment不需要修改,只是文件的更改,那只用 -c参数即可。

转载于:https://my.oschina.net/u/1273644/blog/782468

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值