小丁带你走进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。
这时候看一下它产生的记录结构如下图所示:
本文内容皆为研究成果以及学习文章后总结,如果上述问题有错误之处请指正,我发现截图太多了,应该换一种方式。
导航:
小丁带你走进git世界一-git简单配置
http://www.cnblogs.com/dwlsxj/p/Github.html
小丁带你走进git的世界二-工作区暂存区分支
http://www.cnblogs.com/dwlsxj/p/git.html
转载于:https://www.cnblogs.com/dwlsxj/p/git-revocation-amend.html
小丁带你走进git的世界三-撤销修改相关推荐
- 【密码学】一万字带您走进密码学的世界(下)
引文 密码学是研究编制密码和破译密码的技术科学.研究密码变化的客观规律,应用于编制密码以保守通信秘密的,称为编码学:应用于破译密码以获取通信情报的,称为破译学,总称密码学. 在<一万字带您走进密 ...
- 【密码学】一万字带您走进密码学的世界(上)
引文 密码学是研究编制密码和破译密码的技术科学.研究密码变化的客观规律,应用于编制密码以保守通信秘密的,称为编码学:应用于破译密码以获取通信情报的,称为破译学,总称密码学. 为了使读者对密码学有一个整 ...
- 带你走进rsync的世界
导读 Rsync(remote synchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件,也可以使用 Rsync 同步本地硬盘中的不同目录.rsync共有3种使用方 ...
- git 常用操作,撤销修改
一. 创建与合并分支 1. 从master分支创建dev分支并切换到dev分支: git checkout master git checkout -b dev 其中,git checkout -b ...
- checkout 撤销修改_git命令(10):git 常用操作,撤销修改(2)
一. 创建与合并分支 1. 从master分支创建dev分支并切换到dev分支: git checkout master git checkout-b dev 其中,git checkout -b d ...
- 冷链冷库|果蔬保鲜储藏冷链冷库 海格里斯带你走进果蔬冷库世界
冷链行业涵盖冷冻加工,冷藏贮藏,冷链运输和冷链销售全过程.冷链行业的主要设施包括冷库或低温物流中心.生鲜食品加工中心(包括中央厨房).冷藏运输车.超市陈列柜等.而冷链行业景气度的提升则会带动冷库,冷藏 ...
- Git版本回退和撤销修改
版本回退: 在实际工作中,我们会不断对文件进行修改,然后不断提交修改到版本库里,一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失. ...
- 三子棋小游戏带你走进编程世界(c语言版)
目录 一.游戏实现的整体思路 二.实现游戏大体框架 二.游戏函数的实现 1.初始化键盘 2.打印棋盘 3.下棋及胜负判断 (1)玩家下棋 (2)电脑下棋 (3)判断输赢 三.结语及源码 三子棋想必大家 ...
- vLive带你走进虚拟直播世界
虚拟直播是什么? 虚拟直播是基于5G+实时渲染技术,在绿幕环境下拍摄画面,通过实时抠像.渲染与合成,再推流到直播平台的一种直播技术.尽管这种技术早已被影视工业所采用,但在全民化进程中却是困难重重,面临 ...
- git 撤销挂起的更改_小姐姐带你用Git
首先,Git 是什么? 项目版本管理工具 Git 的工作原理 又 是怎么样的? Git最重要的两个概念:1.工作区和缓存区.版本库 2.master 指针 和 HEAD 指针 现在,小姐姐打开ite ...
最新文章
- WebSocket 中的Netty
- php中函数的默认值,参数的顺序
- Linux下JDK、Tomcat的安装及配置
- 请教如何维护好iis服务器?
- python安装教程(Windows最新)
- 有苹果表的快看看!屏幕存在破裂可能的 苹果将免费更换了
- 第二次团队冲刺第二天
- MyBatis多个接口参数报错:Available parameters are [0, 1, param1, param2], 及解决方法
- java只有jre_只安装了jre可以运行java程序吗
- Map-Reduce
- JVM--Garbage First
- nGrinder Loadrunner vs nGrinder
- yalmip决策变量
- apache 支持apk下载安装
- 几何画板添加背景图片方法
- 只能上QQ不能上网的解决方法
- 多域名HTTPS 证书
- 四川江安戏剧“青年训练营”:播撒颗颗戏剧种子
- Web前端开发的十佳前端框架优缺点
- shell 批量 ping 多个IP地址
热门文章
- C#自学29—简体字繁体字转换
- 科研第二步:远程在服务器上跑程序jupyter使用
- matlab计算六面体的体积,六面体单元体积坐标方法-工程力学-清华大学.PDF
- 20165219王彦博第一周学习总结
- 线程2--主线程(main线程)
- 黄一老师:管理者需要知道的“三多”和“三少”
- java中void是什么意思_JAVA里VOID是什么意思
- JAVA学习笔记——BLOB类型和数据批量操作
- 李沐d2l 环境安装
- Node.jsv12.0 https请求报错