小丁带你走进git的世界三-撤销修改
wptr33 2025-05-26 19:23 8 浏览
一、撤销指令
- 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。
这时候看一下它产生的记录结构如下图所示:
三、结束语
本文内容皆为研究成果以及学习文章后总结,如果上述问题有错误之处请指正,我发现截图太多了,应该换一种方式。
导航:
小丁带你走进git世界一-git简单配置
http://www.cnblogs.com/dwlsxj/p/Github.html
小丁带你走进git的世界二-工作区暂存区分支
http://www.cnblogs.com/dwlsxj/p/git.html
- 上一篇:解决git中的detached问题
- 下一篇:Git使用的奇技淫巧
相关推荐
- 文科生自学Python-生成简单的WORD文档
-
--天行健君子以自强不息,地势坤君子以厚德载物,学习编程成就更好的自己--Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可...
- 使用Python 爬取京东、淘宝等商品详情页的数据,避开反爬虫机制
-
以下是爬取京东商品详情的Python3代码,以excel存放链接的方式批量爬取。excel如下...
- CV学习笔记(二十四):数据集标注与制作
-
最近在做一些数据标注的工作,虽然标注数据比较枯燥,但这也是每个做算法的工程师升级打怪的必由之路。使用一些合适的工具往往可以事半功倍,效率UP。一:数据标注流程二:数据处理的一些小代码1:重命名当得到这...
- 新手常见的python报错及解决方案(如何理解python报错信息)
-
此篇文章整理新手编写代码常见的一些错误,有些错误是粗心的错误,但对于新手而已,会折腾很长时间才搞定,所以在此总结下我遇到的一些问题。希望帮助到刚入门的朋友们。后续会不断补充。...
- 殊途同归python第5节:一键管理所有文档
-
Python自带的os模块,文件和文件夹的小管家,直接上代码importosa=os.getcwd()#获取当前路径,以字符串形式返回当前的绝对路径。os.chdir("动画片收...
- 1.文件夹的处理 OS(文件夹的操作方法)
-
os.getcwd()#当前目录os.listdir()#列出目录下的文件os.path.join()#拼接路径os.path.split()#拆分路径os.path.exists...
- Linux下分析bin文件的10种方法(linux binary文件)
-
这世界有10种人,一种人懂二进制,另一种人不懂二进制。——鲁迅大家好,我是良许。二进制文件是我们几乎每天都需要打交道的文件类型,但很少人知道他们的工作原理。这里所讲的二进制文件,是指一些可执行文件,...
- 文科生自学Python-pandas交叉透视表降维变换
-
--心有猛虎,细嗅蔷薇,学习编程成就更好的自己--...
- 史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)
-
点赞、收藏、加关注,下次找我不迷路...
- Undoing a git rebase(undoing a git rebase)
-
技术背景在使用Git进行版本控制时,gitrebase是一个强大的命令,它可以将一个分支的修改合并到另一个分支,使提交历史更加线性。然而,在某些情况下,我们可能需要撤销...
- 【干货】常用的Git命令有哪些?(git 常用命令行入门)
-
Git是一个开源的分布式版本控制系统,它被广泛用于软件开发中。在使用Git进行版本控制时,有许多常用的命令,本文将对这些命令进行详细的介绍。...
- 项目中使用 husky 格式化代码和校验 commit 信息
-
大家好,我是前端西瓜哥。今天我们学习使用husky工具,在commit的时候做一些风格的校验工作,包括commit信息格式化和文件格式化。githook和husky...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)