『现学现忘』Git后悔药 — 27、版本回退介绍
1、什么版本回退
版本回退也可以叫回滚。
若修改过的文件,不仅添加到了暂存区,还提交到了本地版本库,还能撤销吗?
已经无法撤销修改了,但是可以回退到修改前的版本。
版本回退也是撤销操作的一种,但我更愿意和前两种撤销操作分开理解。
引用廖雪峰比喻:
你不断对文件进行修改,然后不断提交修改到版本库里,就好比玩RPG游戏时,每通过一关就会自动把游戏状态存盘,如果某一关没过去,你还可以选择读取前一关的状态。有些时候,在打Boss之前,你会手动存盘,以便万一打Boss失败了,可以从最近的地方重新开始。
Git也是一样,每当你觉得文件修改到一定程度的时候,就可以“保存一个快照”,这个快照在Git中被称为
commit。一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失。
2、需要了解两个知识点
能够了解是什么即可。
(1)HEAD是什么
HEAD也可以称为HEAD指针。
Git仓库初始化之后,会默认创建一个master分支,即主分支。这是Git对版本进行管理的时间线,即Git的每次提交,都会自动把它们串成一条时间线,这条时间线就是一个分支。
如果没有新建分支,那么就只有一条时间线,即只有一个分支,master分支(主分支)。在这条master时间线上有很多版本的时间节点(提交的commit),而HEAD指针则指向的是当前分支上,刚刚提交的版本时间节点。
如果上面看不太懂的话,就记住:HEAD指针指向分支,分支指向具体commit。所以HEAD指针代表的就是当前工作分支上最新一次的提交。
具体原理以后会总结,这里不详细展开,如下图所示:

(2)HEAD指针用法
上面说了,HEAD指针代表的就是当前工作分支上最新一次的提交。换句话说HEAD这个词就等同于当前工作分支上最新一次提交的别名。
HEAD指针还可以表示相对位置,有几种表示方法:
- 单写
HEAD,表示当前工作分支的最新提交版本。 - 可以通过
^表示前一个版本,例如HEAD^,如要表示前两个版本,则需要加两个^,示例:HEAD^^,以此类推。 - 但是要选择之前版本跨度较多的时候,
^的数量就不是很好数了(书写可读性差),此时可以使用~加数字表示当前版本之前的第几个版本。例如:HEAD~100表示为最新版本的往前第100个版本。 - 当时我们也可以使用
HEAD@{0}的方式进行表示,HEAD@{0}等于HEAD。HEAD@{1}等于HEAD^,也就是前一个版本。值的数字越小,表示版本越新,数字越大表示版本越旧。
HEAD指针的作用示意图:

3、git reflog命令介绍
git reflog命令是用来恢复本地错误操作很重要的一个命令,他和git log命令一样都可以查看本地版本库的历史提交信息。
但是不同的是,git reflog命令能够查看可引用历史提交版本。
可引用历史提交版本,什么意思?
- 使用
git log命令只可以查看到HEAD指针及其之前的版本信息,如果版本发生过回退操作,则可能会出现,HEAD指针之后仍存在历史提交版本的情况,而这些提交版本信息通过git log命令是看不到的。 - 我们可以通过使用
git reflog命令,就可查看到所有历史版本信息。由于查看所有历史版本信息的目的,大多是为了进行版本回退或恢复操作所使用,从中找到所需的commit索引,所以该命令被命名为reflog,即:引用日志。
git log命令与git reflog命令作用范围示意图:

『现学现忘』Git后悔药 — 27、版本回退介绍的更多相关文章
- 『现学现忘』Git后悔药 — 31、reset版本回退命令总结
目录 1.--soft回退说明 2.--mixed回退说明 3.--hard回退说明 4.总结 在Git中进行版本回退需要使用git reset命令. 以前面文章中的示例为例,当我准备在V4版本,回退 ...
- 『现学现忘』Git后悔药 — 32、revert撤销(一)
目录 1.Git的三种后悔药 2.revert命令原理 3.revert命令的使用 (1)移除某次提交的修改 (2)revert命令说明 1.Git的三种后悔药 在Git中后悔药有三种:amend.r ...
- 『现学现忘』Git后悔药 — 28、版本回退git reset --soft命令说明
git reset --soft commit-id命令:回退到指定版本.(soft:柔软的) 该命令仅仅修改分支中的HEAD指针的位置,不会改变工作区与暂存区中的文件的版本. 实现上是只做了一件事情 ...
- 『现学现忘』Git后悔药 — 29、版本回退git reset --mixed命令说明
git reset --mixed commit-id命令:回退到指定版本.(mixed:混合的,即:中等回退.) 该命令不仅修改了分支中HEAD指针的位置,还将暂存区中数据也回退到了指定版本. 但是 ...
- 『现学现忘』Git后悔药 — 30、版本回退git reset --hard命令说明
git reset --hardcommit-id命令:回退到指定版本.(hard:强硬,严格的回退) 该命令不仅移动了分支中HEAD指针的位置,还将工作区和暂存区中数据也回退到了指定的版本. (提示 ...
- 『现学现忘』Git后悔药 — 34、git commit --amend 命令
目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...
- 『现学现忘』Git后悔药 — 33、revert撤销(二)
目录 4.一次移除某几次提交 (1)git revert移除某几次提交的修改 (2)git revert 移除某几次连续的提交的修改 5.revert命令常用参数 6.git revert和git r ...
- [原]git的使用(一)---建立本地仓库、add和commit、status和git diff、版本回退使用git reset
在window下已经安装了git的环境 1.建立本地仓库 mkdir test #建立test目录 cd test #进入目录 git init # ...
- Git使用:版本回退
在Git中,我们可以用 git log命令查看我们修改的历史记录 C:\Users\Administrator\Documents\GitHub\learngit [master]> git l ...
随机推荐
- 马里奥制造,Ready~~GO!「GitHub 热点速览 v.22.16」
作者:HelloGitHub-小鱼干 如果你有创造力,就可以以马里奥 Mario 为主角在 a-little-game-called-mario 中开启你的 Hell 模式 Mario:如果你想贡献代 ...
- javaScript深拷贝和浅拷贝简单梳理
在了解深拷贝和浅拷贝之前,我们先梳理一下: JavaScript中,分为基本数据类型(原始值)和复杂类型(对象),同时它们各自的数据类型细分下又有好几种数据类型 基本数据类型 数字Number 字符串 ...
- Java多线程—线程同步(单信号量互斥)
JDK中Thread.State类的几种状态 线程的生命周期 线程的安全问题(同步与互斥) 方法一:同步代码块 多个线程的同步监视器(锁)必须的是同一把,任何一个类的对象都可以 syn ...
- CSAPP 之 DataLab 详解
前言 本篇博客将会剖析 CSAPP - DataLab 各个习题的解题过程,加深对 int.unsigned.float 这几种数据类型的计算机表示方式的理解. DataLab 中包含下表所示的 12 ...
- slice-substring-substr-split-splice
一.字符串slice(startIndex, endBeforeIndex) endBeforeIndex < 0,则 endBeforeIndex 为 负数,第二个参数为字符串长度加上负值,之 ...
- 移动端input的disabled属性对字体颜色影响
对于表单输入,input是很好的选择,这次记录主要是正对input的value值字体在Android和iOS(11)设备下显示不同问题: 如下图:1.2的区别主要是分别设置disabled.reado ...
- range内部代码
def my_range(a, b=None, c=1): if not b: b = a a = 0 while a < b: yield a a += c
- Java高并发-无锁
一.无锁类的原理 1.1 CAS CAS算法的过程是这样:它包含3个参数CAS(V,E,N).V表示要更新的变量,E表示预期值,N表示新值.仅当V值等于E值时,才会将V的值设为N,如果V值和E值不同, ...
- vue ui 创建vue项目 没反应的解决办法 2021
1.升级vue 脚手架 即可 2.再 vue ui 创建项目 cnpm i -g @vue/cli
- 源码解读etcd heartbeat,election timeout之间的拉锯
转一个我在知乎上回答的有关raft election timeout/ heartbeat interval 的回答吧. 答:准确来讲: election是timeout,而heartbeat 是in ...