1、Git的三种后悔药

在Git中后悔药有三种:amendrevertreset

  • git commit --amend:新的提交覆盖上一次提交的内容。
  • git revert:提交一个新的commit,来撤销之前的commit
  • git reset:直接回滚到指定的commit

    --soft:只回退版本库,工作区和暂存区的内容不回退。

    --mixed(默认):回退版本库和暂存区,工作区中的内容不回退。

    --hard:工作区,暂存区,版本库中的内容都回退到指定的提交。(危险的)

提示:之前我们把git reset命令说完了,git commit --amend命令我们下一篇文章说。这篇文章来说git revert命令。

2、revert命令原理

在我们使用Git的操作中,遇到需要回滚代码的情况几乎是难以避免的,而 git revert 命令是一个非常实用的功能,掌握好 git revert 命令的使用是很有必要的。

git revert命令:是用于“反做”某一个版本,以达到撤销该版本的修改的目的。

比如,我们提交了三个版本,突然发现版本二不行(如:有bug),想要撤销版本二,但不想或不需要撤销版本三提交,就可以用 git revert 命令来反做版本二,同时生成新的版本四,这个版本四里会保留版本三的东西,但撤销了版本二的东西。

但注意:版本二的历史提交记录是不会删除的。

如下图所示:

提示:注意是revert命令撤回某个改动,不是reset命令撤回到某个改动。另外,这条命令不会删除任何commit记录,而是会新增一条revert操作的commit记录(会弹出commit message的编辑窗口)。

3、revert命令的使用

现有一个版本库,其中有4次提交,版本库的历史提交记录如下:

L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ git log --oneline
c04b29c (HEAD -> master) 第4次提交,新增内容:revert test v4
fd819dc 第3次提交,新增内容:revert test v3
c71ae3c 第2次提交,新增内容:revert test v2
557f7c3 第1次提交,新增readme.txt文件

我们发现第三次提交和第四次提交有错误,需要撤销。

如下图:

(1)移除某次提交的修改

commit-1commit-2 是正常提交,而 commit-3commit-4 是错误提交。现在,我们想把 commit-3commit-4 撤销掉。而此时,HEAD 指针指向 commit-4 提交(c04b29c)。我们只需将 HEAD 指针移动到commit-2 提交(c71ae3c),就可以达到目的。

我们一定会想到之前学过的 git reset 命令。执行命令git reset --hard c71ae3c,就可以退回到 commit-2 提交。

采用这种方式回退代码的弊端显而易见,那就是会使 HEAD 指针往回移动,从而会失去之后的提交信息。将来如果突然发现, commit-3commit-4 是多么绝妙的想法,可它们已经早就消失在历史的长河里了(但是通过reflog也能找回来)。

而且,有些公司明令禁止使用 git reset 命令去回退代码,原因与上述一样。所以,我们需要找到一个命令,既可以回退代码,又可以保存错误的提交。这时 git revert 命令就派上用场了。

命令:git revert <commit>

演示:

# 1.撤销第四次提交
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ git revert c04b29c
[master d0c8e48] Revert "第5次提交,revert 撤销第4次提交"
1 file changed, 1 deletion(-) # 之后会弹出一个编辑文本框,来让你写新生成提交的注释,如下图。 # 2.查看版本库历史提交记录
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ git log --oneline
d0c8e48 (HEAD -> master) Revert "第5次提交,revert 撤销第4次提交"
c04b29c 第4次提交,新增内容:revert test v4
fd819dc 第3次提交,新增内容:revert test v3
c71ae3c 第2次提交,新增内容:revert test v2
557f7c3 第1次提交,新增readme.txt文件
# 可以看到第4次提交的commit依然存在。 # 3.查看readme.txt文件内容
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ cat readme.txt
revert test v1
revert test v2
revert test v3
# 可以看到V4 版本内容已经没有了。

如下图所示:

这里需要说明一下:

git revert命令的作用通过反做创建一个新的版本,这个版本的内容与我们要回退到的目标版本一样,但是HEAD指针,是指向这个新生成的版本,而不是目标版本。

使用 git revert 命令来实现上述例子的话,我们可以这样做:先 revert commit-4,再 revert commit-3有多个提交需要回退的话需要由新提交到旧提及哦啊进行 revert)。

我们继续同样的操作步骤,把第三次提交也撤销掉。

# 1.撤销第3次提交
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ git revert fd819dc
[master 30f7626] Revert "第6次提交,revert 撤销第3次提交"
1 file changed, 1 deletion(-) # 2.查看版本库历史提交记录
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ git log --oneline
30f7626 (HEAD -> master) Revert "第6次提交,revert 撤销第3次提交"
d0c8e48 Revert "第5次提交,revert 撤销第4次提交"
c04b29c 第4次提交,新增内容:revert test v4
fd819dc 第3次提交,新增内容:revert test v3
c71ae3c 第2次提交,新增内容:revert test v2
557f7c3 第1次提交,新增readme.txt文件 # 3.查看readme.txt文件内容
L@DESKTOP-T2AI2SU MINGW64 /j/git-repository/revert_test (master)
$ cat readme.txt
revert test v1
revert test v2

通过上面练习,我们可以得出,git reset撤销和git revert撤销的区别,如下图所示:

(2)revert命令说明

git revert <commit>命令:

  1. 这个命令会生成一个新的提交记录,新的提交记录就是把需要移除的提交撤销掉,所生成的新提交。
  2. 如果工作区或暂存区还有修改未提交,那么会提示需要先提交或存储起来这些文件。
  3. 如果在移除的过程中发生了冲突,可以在解决了冲突后,使用 git add 命令添加修改的冲突文件到暂存区中,在使用 git revert --continue 来继续操作。

    如果不想继续操作,当然也可以使用 git revert --abort 命令来停止移除操作,恢复到执行git revert <commit>命令之前的状态。
  4. 如果revert移除的过程中出现冲突,需要把这些冲突解决才可以继续操作。我们可以使用 git revert --skip 命令来跳过一个commit的冲突解决。如果后续还有冲突,也同样如此进行跳过,直到全部冲突解决完成。

    但是使用git revert --skip 命令跳过的commit,将会在历史提交记录中被删除(reflog命令还是可以看到的),所以git rebase --skip 这个命令慎用。

拓展思路:

  • git revert HEAD:撤销前一次commit
  • git revert HEAD^:撤销前前一次commit

『现学现忘』Git后悔药 — 32、revert撤销(一)的更多相关文章

  1. 『现学现忘』Git后悔药 — 33、revert撤销(二)

    目录 4.一次移除某几次提交 (1)git revert移除某几次提交的修改 (2)git revert 移除某几次连续的提交的修改 5.revert命令常用参数 6.git revert和git r ...

  2. 『现学现忘』Git后悔药 — 34、git commit --amend 命令

    目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...

  3. 『现学现忘』Git后悔药 — 27、版本回退介绍

    目录 1.什么版本回退 2.需要了解两个知识点 (1)HEAD是什么 (2)HEAD指针用法 3.git reflog命令介绍 1.什么版本回退 版本回退也可以叫回滚. 若修改过的文件,不仅添加到了暂 ...

  4. 『现学现忘』Git后悔药 — 28、版本回退git reset --soft命令说明

    git reset --soft commit-id命令:回退到指定版本.(soft:柔软的) 该命令仅仅修改分支中的HEAD指针的位置,不会改变工作区与暂存区中的文件的版本. 实现上是只做了一件事情 ...

  5. 『现学现忘』Git后悔药 — 29、版本回退git reset --mixed命令说明

    git reset --mixed commit-id命令:回退到指定版本.(mixed:混合的,即:中等回退.) 该命令不仅修改了分支中HEAD指针的位置,还将暂存区中数据也回退到了指定版本. 但是 ...

  6. 『现学现忘』Git后悔药 — 30、版本回退git reset --hard命令说明

    git reset --hardcommit-id命令:回退到指定版本.(hard:强硬,严格的回退) 该命令不仅移动了分支中HEAD指针的位置,还将工作区和暂存区中数据也回退到了指定的版本. (提示 ...

  7. 『现学现忘』Git后悔药 — 31、reset版本回退命令总结

    目录 1.--soft回退说明 2.--mixed回退说明 3.--hard回退说明 4.总结 在Git中进行版本回退需要使用git reset命令. 以前面文章中的示例为例,当我准备在V4版本,回退 ...

  8. 『现学现忘』Git基础 — 5、Git的协作模式

    目录 1.分布式工作流程 2.集中式工作流 3.分支工作流 4.GitFlow 工作流(最流行) 5.Forking 工作流(偶尔使用) 6.总结 1.分布式工作流程 与传统的集中式版本控制系统(CV ...

  9. 『现学现忘』Git基础 — 23、Git中的撤销操作

    目录 1.撤销操作说明 2.撤销工作区中文件的修改 3.撤销暂存区中文件的修改 4.总结 1.撤销操作说明 我们在使用Git版本管理时,往往需要撤销某些操作.比如说我们想将某个修改后的文件撤销到上一个 ...

随机推荐

  1. IDEA自定义liveTemplates(方法模板、类模板)

    IDEA自定义liveTemplates(方法模板.类模板) 前言,搞这个模板有何意义? 降低大家写方法注释的成本,统一风格.有时候不是开发同学不爱写注释,而是没有合适的载体和空间. IDEA模板设置 ...

  2. Java学习第五周

    这周学习了异常与多线程,线程使用 Exception异常的分类: 1.编译时异常:继承自Exception的异常或者其子类,编译阶段就会报错 2.运行时异常:继承自RuntimeException的异 ...

  3. [NCTF2019]Fake XML cookbook-1|XXE漏洞|XXE信息介绍

    1.打开之后显示如图所示: 2.根据题目名字就能看出来和xml有关,和xml有关的那就是注入,brup抓包看下数据包,结果如下: 3.查看post数据,确实很像xml实体注入,那就进行尝试以下,将po ...

  4. Nginx 限制上传文件的大小。responded with a status of 413 (Request Entity Too Large)

    # 限制请求体的大小,若超过所设定的大小,返回413错误. client_max_body_size 50m; # 读取请求头的超时时间,若超过所设定的大小,返回408错误. client_heade ...

  5. 基于ABP的AppUser对象扩展

      在ABP中AppUser表的数据字段是有限的,现在有个场景是和小程序对接,需要在AppUser表中添加一个OpenId字段.今天有个小伙伴在群中遇到的问题是基于ABP的AppUser对象扩展后,用 ...

  6. 一分钟安装DolphinScheduler并上手体验

    一分钟安装Apache DolphinScheduler并上手体验 1 一分钟安装DolphinScheduler并上手体验 本教程基于DolphinScheduler1.3.2 2 需要准备: 一台 ...

  7. 如何在BI中增加“路线地图”并进行数据分析?

    随着客户的需求越来越"百变",最近在做大屏设计的葡萄陷入了困境. 近期客户提出的需求是想在BI工具中增加 "路线地图"展示功能并进行数据分析. 不仅如此,这个& ...

  8. day20--Java集合03

    Java集合03 8.LinkedList 1)linkedList底层实现了双向链表和双端队列的特点 2)可以添加任意元素(元素可以重复),包括null 3)线程不安全,没有实现同步 LinkedL ...

  9. Ceph创建一个新集群 报错: File "/usr/bin/ceph-deploy", line 18, in..........

    [root@ceph-node1 ceph]# ceph-deploy new node1 Traceback (most recent call last): File "/usr/bin ...

  10. 使 Word 段落第一行空出两个字符的位置(段落首行缩进)

    描述 使 Word 段落第一行左突出两个字符的位置,即段落首行缩进的方式有两种. "视图"选项卡--"显示"组--标尺 "开始"选项卡--& ...