小丁带你走进git的世界三-撤销修改

一、撤销指令

  • git checkout还原工作区的功能
  • git reset  还原暂存区的功能
  • git clean  还没有被添加进暂存区的文件也就是git还没有跟踪的文件可以使用这个命令清除他们
  • git revert 撤销本次提交。

二、指令讲解

Git checkout

首先我们对文件的一个修改,对master.txt进行了修改

修改结果我们利用上面的知识来进行查看。

新增加了Test这么一段话,如果我们想要将工作区的内容添加到暂存区会使用git  add这个命令,如果我们想要还原工作区内容这时候就要用的git checkout命令,实际上做的工作是用暂存区的内容来覆盖我们工作区的内容。看下面操作:

查看一下git status

发现我们之前的修改被还原了。

这时候我们在对master.txt进行修改并添加到暂存区里面去。修改内容如下

修改完成之后我们来进行提交到暂存区,使用git add 命令。这时候再次查看下状态就变成了changes to be committed的状态。

我们可以使用git  reset  HEAD(HEAD~2)这种方式进行还原到某一个提交记录上。因为HEAD所指向的commit就是我们想要恢复的内容,也就是我们HEAD指向的commit就是我们要用这些数据覆盖暂存区数据。

这时候我们在git status看一下,暂存区的内容就被还原了。

我们可以使用这种还原工作区

Git checkout v0 — master.txt ,v0是指向首次提交的commit的记录(这里的v0是给commit打的一个tag记录)。我们来看一下工作区和暂存区的区别:

发现少了一行提交内容。我们这时候再用当前HEAD指向的commit还原一下工作区就可以了。

这时候就没有了区别了。使用提交记录还原暂存区的内容格式和checkout是一致的这里就不做演示了。(例如用v0 tag的记录还原暂存区,git reset v0 – master.txt还原指定文件)

在工作区内新建两个文件然后不将文件添加到暂存区内,使用git clean进行清理。

这时候使用git clean –n将要删除的文件展示出来。

这时候再用git  clean –f进行删除掉这些文件。

我们在这里新建一个vim  .gitignore的文件过滤掉后缀为o和a的文件。

添加到历史记录里面去,然后在新建文件进行清理。

新建了三个文件test.o、test1.a、test2.c这时候我们来使用git clean –n的时候就会显示一条清除记录就是test2.c,默认他不清理gitignore里面的文件。

这里我们正好相反我们想要保留ignore以外的文件,清理掉ignore里面的文件。这时候我们就会用到下面的这个指令git  chean  -n  -X后面跟一个大写的X,我们发现得到了我们想要的结果。

我们执行它,清理掉这些文件。git  chean  -X –f这时候就清理了.o和.a的文件

我们可以使用git revert产生一个新的提交来覆盖我们不想要的上面的ignore提交记录。git revert  HEAD

下面来演示下git revert的工作原理:

第一种情况:当我们第一次提交记录时就revert。当我们用touch 生成一个文件a,生成后将a文件放入到暂存区,这时候就会产生一个a的git对象,这个对象存放在.git/objects目录,如下图所示:

当我们还有add的时候objects文件下面就两个默认文件夹。当git add的时候就会产生一个git对象。

这个就是git对象,一个文件对应一条内容,以该内容加上特定头部信息一起的 SHA-1 校验和为文件命名。 校验和的前两个字符用于命名子目录,余下的 38 个字符则用作文件名。这里不作详解。那么整体的sha-1校验和就是文件名+子目录名。当我调用git commit 的时候会产生一个树对象一个commit对象,并且commit对象指向树对象。

接下来我们来看一下那个sha-1是树对象哪一个是commit对象,并且验证下commit对象下面是不是树对象。

整体生成本次提交的结构如下图所示:

当我们git revert的时候会产生一个新的tree对象,这个tree对象是创建一个撤销上次修改的tree对象。

就变成了现在这个样子了。

还有第二种情况就是我们第二次提交之后再进行revert的时候这时候就会生成一个新的commit指向原来的tree对象。接下来我们就来演示下

首先第一步就是初始化一个仓库这里就不多说了,第二部就是下面图的步骤先新建两个文件a,b两个文件,然后将a和b文件分别添加到暂存区中,这时候就会产生git对象,我们来看一下git对象的类型,确定是blob类型,然后将暂存区的文件提交到记录中。演示如下图所示:

接下来就在查看下.git/objects文件下面生成的对象以及对象的类型,然后我们就开始准备第二题提交,首先编辑下a文件添加到暂存区里面这时候会产生一个git对象(blob)。如下图所示:

这时候就能看到我们新增加的git对象内容以及sha-1。

接下来我们就要查看新生成对象的类型,在进行第二次提交git  commit,当我们提交之后会生成新的对象,再看一下新对象类型的属性,刚好查看第一个对象是commit对象看一下他的内容。详细请见下图:

接下来就要看一下tree对象以及tree对象下的元素都有哪些,详情请见下图

那么这是我们看一下它产生的记录结构如下图所示:

当我们revert之后,就会生成一个新的commit将指向第一次提交的tree对象。我们来看一下新生成的commit对象的sha-1。

这时候看一下它产生的记录结构如下图所示:

三、结束语

本文内容皆为研究成果以及学习文章后总结,如果上述问题有错误之处请指正,我发现截图太多了,应该换一种方式。

时间: 2024-10-20 07:23:47

小丁带你走进git的世界三-撤销修改的相关文章

小丁带你走进git的世界三-撤销修改(转)

一.撤销指令 git checkout还原工作区的功能 git reset  还原暂存区的功能 git clean  还没有被添加进暂存区的文件也就是git还没有跟踪的文件可以使用这个命令清除他们 git revert 撤销本次提交. 二.指令讲解 Git checkout 首先我们对文件的一个修改,对master.txt进行了修改 修改结果我们利用上面的知识来进行查看. 新增加了Test这么一段话,如果我们想要将工作区的内容添加到暂存区会使用git  add这个命令,如果我们想要还原工作区内容

小丁带你走进git的世界四-重写历史记录

一.git对象文件创建 开篇先补充一个知识点,就是比如我建立一个文件之后,使用git add就会生成一个git对象,但是git对象生成后可以在.git/objects里面对应,首先我们来初始化一个仓库git init. $ git init 然后我们来创建两个文件文件名分别为a和b. $ touch a b 将a文件添加到暂存区,然后再将b添加到暂存区,我们会想到这时候有两个git对象产生,但是git对象对应.git/objects文件. $ git add . $ find .git/obje

小丁带你走进git世界五-远程仓库

一.文件,指令讲解 首先讲一下远程仓库和本地仓库在文件上面的区别,首先我们来看下对比图(当然这里说的区别是在于.git文件下面的文件内容,至于里面内容我们不会关注)這裡我们进行了相同的操作就是本地仓库里面新建了version.txt内容也是一样的v1.0: 图一 图二 图一为本地仓库,图二为克隆的远程仓库,首先我们应该看一下config里面的区别: 图三 图四 很容易看到了区别就是图四为远程仓库内容. 从这个文件中我们可以了解到: 1,本地库的当前分支为master,其关联的远程库名称为orig

小丁是怎样入门git的

0x01前言 既然没有华丽的出场,那就平凡的分享,首先我要说明一点本篇文章针对Git初学者,对我自己学Git的资源的整合,其实本篇索引应该在我写Git系列文章的时候就紧跟着放上索引的,由于时间问题没有来得及整理,这里我详细整理下文章内容.其实说到git的文章已经很多了,这里分享下我的学习过程和自己摸索的过程. 个人整理Git学习资源请点击这里:(yes,I’m here)       1.小丁带你走进Git世界一-git简单配置 http://www.cnblogs.com/dwlsxj/p/G

小心公共wifi 之小白客带你走进黑客世界:kali linux下的无线攻击技术

本文标签: 黑客世界 wifi安全 无线攻击技术 公共wifi不安全 kali+linux 原文地址:http://whosmall.com/?post=460 我们常说公共wifi不安全,那么到底不安全在哪些地方呢?当不怀好意者和你同在一个wifi下,你的手机或者笔记本会被监听吗?除了上网被监视以外,还会产生什么不好的后果?介于小伙伴们对于wifi这一块比较感兴趣,在这篇文章里,就先为大家普及一下在公共wifi下究竟有多危险. 实验环境 一台装有kali linux的笔记本(模拟攻击者)ip地

【密码学】一万字带您走进密码学的世界(下)

引文 密码学是研究编制密码和破译密码的技术科学.研究密码变化的客观规律,应用于编制密码以保守通信秘密的,称为编码学:应用于破译密码以获取通信情报的,称为破译学,总称密码学. 在<一万字带您走进密码学的世界(上)>的文章中我们探讨了对称密码体系,哈希函数等技术,本文继续探讨密码学剩余的部分,本文的主要内容包括,非对称密码体系,签名算法等,因为本部分是区块链技术的基石,所以我会讲的更加详细一点,虽然我已经尽最大努力使思想简化,但是其中的数学理论对于很多人还是很晦涩,建议读者开始之前先读下数论的有关

详解C++引用——带你走进引用的世界

 一.介绍引用 首先说引用是什么,大家可以记住,引用就是一个别名,比如小王有个外号叫小狗,他的妈妈喊小狗回家吃饭,那就是在喊小王回家吃饭. 接下来我们用两行代码来声明一个引用(就拿小王和小狗来说吧): int xiaoW; int &xiaoG=xiaoW; 上面就是一个引用,说明几点要注意的地方: 1.&不是取地址符,而是引用运算符: 2.xiaoG是xiaoW的别名,所以这两个变量的值和地址都是一样的: 3.引用只能初始化,而不能先声明再赋值,因为引用就相当于一个常量: 4.在声明

【密码学】一万字带您走进密码学的世界(上)

引文 密码学是研究编制密码和破译密码的技术科学.研究密码变化的客观规律,应用于编制密码以保守通信秘密的,称为编码学:应用于破译密码以获取通信情报的,称为破译学,总称密码学. 为了使读者对密码学有一个整体的认识,本文简述了常见的密码学的概念,其中本文包括对称密码,哈希函数.<一万字带您走进密码学的世界(下)>包括非对称密码,数字签名,数字认证等,需要指出的是文中并没有深入探讨加密算法原理,关于此部分内容,后续的文章会详细阐述.本文的主要内容如下图所示: 对称密码 在对称密码体系中,相同的密码用来

带你走进rsync的世界

导读 Rsync(remote synchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件,也可以使用 Rsync 同步本地硬盘中的不同目录.rsync共有3种使用方法,在配置rsync也是有6个步骤的.下面我们就从rsync的介绍,rsync的使用和rsync的配置带你走进rsync的世界 一.rsync简介 Rsync(remote synchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件,也可以使用 Rsync 同步本地