在开发时自己提交了多个commit后,突然发现其中有一个commit带有bug, 如何解决?平时用git用的比较简单,一般我都是git commit -am "commit msg“ + git push联合操作,快速提交,今天被问到了这个问题,一时间答不上来,就仔细学习并整理了一个git的解决办法。
1.最简单直接的办法:直接在新一次的提交commit中,修复发现的这个bug,这样不需要回撤之前的提交,不需要做复杂的处理,只是会多一次commit的记录。想想我自己常常就是这么做的,真是很糙很不优雅的一种做法,但好在简单快捷有效。这种方法不论是本地的错误还是已经提交到远端的错误,都可以使用。
2.使用git reset解决--这种方法一般适用于本地进行了多次commit但是还没提交到远端
git reset --hard : 是一种强操作,慎用!比如使用 git reset --hard 4ac3e5a43d48476a9e6680f07787d6954cf56964(这个是想到达的commitid),会将工作区working tree,暂存区index/stage,以及repository的代码全都变到指定的commitid版本。假设这个commitid之后的所有代码都不想要了,可以执行这个命令,一般不用。
git reset --soft:保留working Tree工作目录和index暂存区的内容,只让repository中的内容和 reset 目标节点保持一致,因此原节点和reset节点之间的【差异变更集】会放入index暂存区中(Staged files)。所以效果看起来就是工作目录的内容不变,暂存区原有的内容也不变,只是原节点和Reset节点之间的所有差