Tool--git commit提交错误后如何解决

在开发时自己提交了多个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节点之间的所有差

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进阶的小猫

觉得不错就打赏1元鼓励小姐姐呀

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值