一把剪刀看懂git reset 和它的三个参数

都说git 命令难记且难懂,但是如果从立体的角度看待git与git管理的版本,那么一切都会明朗许多。

大多数的学习教程为了理解git,会绘制几个圆圈的串联,每个圆圈代表一个commit的版本,也就是从时间线上看git 是一串commit。大多数时候这样的理解是足够了,但是如果当使用git reset 命令的时候这样的一串圆圈并不能帮助我们理解git reset 加上--hard、--soft和--mixed这三个参数究竟会发生什么。

比如git reset commit B --soft, 我们的工作目录是什么样子,stage里面是什么?

使用串联起来的圆圈的模型会让我们无所适从,而许多人应该都是通过记忆这个命令产生的效果来知道这个命令之后代码处于什么状态,或者是用多了也就知道了,或者是搜索一下。

实际上,如果我们使用本文一开始的图片来理解,不用搜索,不用使用很多次(大部分时候用了好多次也会忘记),就会知道git reset 那三个参数发生了什么。

使用git reset 命令的时候,头脑里面浮出图片, 然后想象自己手中拿着一把剪刀,当使用git reset --mixed commit x时,就是把commit x 的红色的线剪掉,这时候我们就处在commit x的最下面,也就是我们的working dir相当于我们将要把版本x 进行add和commit的时候。

如果使用的是git reset --soft commit x, 就是用剪刀剪掉了commit x的黄色的线,我们这时候处于stage了代码,将要把代码commit 成x的阶段。

如果使用了git reset --hard commit x,就是用剪刀剪掉了 commit x左边的黑色线条,这时候我们处于commit x的前一个commit 中,比如x等于B,那么我们这时相当于刚刚commit了A。

原文首发于:https://zhuanlan.zhihu.com/p/28642742

原文地址:https://www.cnblogs.com/celthi/p/7401317.html