关于Git的版本问题

时间:2021-02-03 13:08:05

问题的起源

我在IDEA上不小心修改了文件(加了一行空行)并且被保存了,在GitHub Desktop桌面工具上可以看到changes中有修改记录,并且使用命令行git status也可以看到文件的修改状态。

于是,问题来了,这个修改并非我的初衷,想要退回去修改前的状态该怎么办?使用Ctrl + Z无效(我想是因为我修改保存之后曾经退出过IDEA工具)。我尝试使用IDEA的Git工具直接Revert,结果退回到了前一个版本(使用IDEA的Show Current Revision即可看到当前commit版本),这并非我所想要。但是,使用命令行执行git rev-parse HEAD却显示仍然在当前commit版本。这就有意思了,当前的实际commit版本究竟是什么呢?如果想要避免踩坑,我想最直接的方式是使用git reset --hard commit_id命令来退回了,其实我无意修改了文件之后并未提交commit。这也是Git与SVN的最大区别,假若换做是SVN,直接删除文件,再执行svn update问题就可以解决了。这也是使用Git比较尴尬的地方。

在思考这个问题的同时,我接触到了 代码回滚:git reset、git checkout和git revert区别和联系 这篇博客,感觉写的还挺详细的,但与我目前遇到的实际场景不太匹配,也许以后会用得到。只能感慨,Git在原理设计上思维方式是比较独特的,与SVN差异太大了,甚至砍掉了一些便捷的方式。但是,仍然瑕不掩瑜。

后记

事后,我认真探究了IDEA的Git机制,发现IDEA似乎存在这样一个逻辑——IDEA的Show Current Revision功能总是显示当前文件的最近一次改变的commit提交(因此不难解释为何显示current commit id的事情了),因此,IDEA的Revert功能仅仅只是把当前文件回归到该文件的最近一次commit版本状态。