使用svn的时候,经常提交之后发现提交的版本有问题。然而没有很简单的方法能够撤销提交,只能用新版本覆盖;而git却可以..
1. 首先提交了一个版本,然后发现这个版本有问题:可能是代码有bug,或者comment写的不对。svn基本对这种情况无能为力,只能再提交一个版本。这样版本库就会存在一个版本是“坏的”
2. git reset --soft 可以将提交撤销,却保留对文件的修改。就好象没有执行git commit一样。 HEAD^ 应该是类似svn的 PREV,指的是上一个版本。
3. 修改代码....
4. 重新提交。git将上次提交的head放到了.git/ORIG_HEAD,可以直接使用;如果连comment也想修改,就不用-c ORIG_HEAD了
-----
HEAD^ 是上一个local的commit(merge,pull下来的不算),可以认为是本人上一个提交的commit