git使用笔记(七)版本回退和撤销
By francis_hao Nov 21,2016
从版本库初始化开始,每一步的撤销操作
添加第一个文件
在空的版本库中创建了一个文件并git add到了缓存区,这时候怎么撤销呢?
撤销单个文件和整个目录
$ git rm --cached a
$ git rm --cached . -r
首次commit内容不能撤销,不过一旦提交了一次之后,git就能发挥它强大的版本控制作用了
修改了文件
在本地修改了文件,但是还没有add操作,也就是撤销本地的修改
撤销单个文件和整个目录,"--"虽然可以省略,但还是以规范为重。表示检出文件,而不是分支
$ git checkout -- a
$ git checkout --
.
add了修改的文件
将修改的文件add到了缓存区,后悔了想撤销但本地的修改不变
撤销单个文件和整个目录
$ git reset HEAD c
$ git reset HEAD .
reset有几种模式,默认模式为mixed,也就是将版本库和缓存区里的重置,但本地文件不动。
commit了修改的文件
将修改的文件commit到版本库里了,若需要撤回到之前的版本,如下图,共有5次提交,目前在E位置,想回到C位置
$ git reset --hard C_value
这样就直接回到C位置,后面的两次提交被舍弃了。当然还可以通过git reflog查看哈希值再返回。
还有一种方式是,HEAD保留在E位置,但是,工作目录里的所有文件替换称C位置的。
$ git checkout C_value -- .
撤销某次提交
还是以上面的5次提交为例,发现在C提交的内容中引入了错误,需要取消C的提交,但是C之后的D和E提交需要保留。
以我的理解,git的具体做法是将B、C和E三者进行比较(至于如何比较参考下文附注),如果可以合并,git会自动合并,如果不能自动合并,就需要手动解决冲突了。
$ git revert C_value
如果有冲突,不想解决,想取消revert
$ git revert --abort
有冲突,解决了之后
$ git add <file_that_conflict>
$ git revert --continue
其中add为了让git知道冲突已经解决了,根据需要add也许是rm或mv
附注
在使用git revert时,有一个问题困扰了我很久,就是git是如何实现合并的,因为有时候觉得明明可以合并的却出现了冲突,下面以几个实验说明自己的猜想
自动合并成功举例
第一个例子是可以成功合并的,没有冲突发生,选取了B、C、D和E四个位置的文件内容。其中D位置认为没有作用。认为文件有两处差别,分别用1和2表示,1B表示第一处差别的B位置。
合并后的结果如下
根据合并后的结果推断合并过程
1B≠1C=1E =>差别删除
2B=2C≠2E =>差别保留
自动合并失败举例
第二例自动合并失败,提示有冲突,此处认为仅有一处差别
推断合并过程
1B≠1C≠1E =>自动合并失败
自动合并成功-补充
本例也是和并成功的例子,和第一例不同处仅仅为1C处的修改,但并不会影响结果。是不是就可以说明D位置不会参与比较合并的过程呢?
本文由 刘英皓 创作,采用 知识共享 署名-非商业性使用-相同方式共享 3.0 中国大陆 许可协议进行许可。欢迎转载,请注明出处:
转载自:http://www.cnblogs.com/yinghao1991/p/6091613.html
参考
[1] git help revert
[2] 廖雪峰 http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 Git教程
[3] geeeeeeeeek/git-recipes https://github.com/geeeeeeeeek/git-recipes/wiki/ 代码回滚:Reset、Checkout、Revert的选择
git使用笔记(七)版本回退和撤销的更多相关文章
- Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突
Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突 这篇是接着上篇分布式版本库--Windows下G ...
- Git版本回退和撤销修改的区别
在阅读廖雪峰git教程时,对版本回退和暂存区撤销修改没太看懂,所以自己测试了一下. 版本回退: git reset --hard HEAD 这个命令用于版本回退,就是将已提交的版本覆盖本地工作区的内容 ...
- Git版本回退和撤销修改
版本回退: 在实际工作中,我们会不断对文件进行修改,然后不断提交修改到版本库里,一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失. ...
- GIT入门笔记(10)- 多种撤销修改场景和对策
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file. 场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步, ...
- Git学习笔记三--管理修改、撤销修改、删除文件
1.管理修改 什么是修改?比如你新增了一行,这就是一个修改,删除了一行,也是一个修改,更改了某些字符,也是一个修改,删了一些又加了一些,也是一个修改,甚至创建一个新文件,也算一个修改. 为什么说Git ...
- 【git】远程仓库版本回退方法
1 简介 最近在使用git时遇到了远程分支需要版本回滚的情况,于是做了一下研究,写下这篇博客. 2 问题 如果提交了一个错误的版本,怎么回退版本? 如果提交了一个错误的版本到远程分支,怎么回退远程分支 ...
- 【Git】三、版本回退&撤消修改&文件删除
提要 //查看git操作日志 $ git log //单行格式查看操作日志 $ git log --pretty=oneline //还原操作到上一次版本,有几个^就上几次 $ git reset - ...
- 『现学现忘』Git后悔药 — 27、版本回退介绍
目录 1.什么版本回退 2.需要了解两个知识点 (1)HEAD是什么 (2)HEAD指针用法 3.git reflog命令介绍 1.什么版本回退 版本回退也可以叫回滚. 若修改过的文件,不仅添加到了暂 ...
- Git时光机穿梭之版本回退
现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...
- 第二课 ---git时光穿梭(版本回退)
1. git status 掌握仓库当前的状态. 2. git diff 查看修改的内容部分. //版本回退: 1.查看更新的历史记录. git log git log --pretty=o ...
随机推荐
- scala映射和元组
scala映射,是一对键值对,相当于java中的Map 对偶:由两个值构成的组,形式 : 值1->值2,值1和值2类型不一定要相同,可以理解为对偶就是一个key/value 映射就是对偶的集合 ...
- flask的自定义过滤器
过滤器的本质是函数.当模板内置的过滤器不能满足需求,可以自定义过滤器.自定义过滤器有两种实现方式: 一种是通过Flask应用对象的 add_template_filter 方法 通过装饰器来实现自定义 ...
- ThinkPHP中的pathinfo模式和URL重写
语文一直不太好,要我怎么解释这个pathinfo模式还真不知道怎么说,那就先来一段代码说下pathinfo模式吧 http://serverName/appName/module/action/id/ ...
- 常用数字信号的产生(C实现)-ARMA模型数据生成
ARMA模型属于信号现代谱估计的范畴,AR模型常用于信号的线性预测.AR模型最后归结为线性方程,MA最后为非线性方程,因此,AR模型使用较多. AR模型最后归结为解Yule-Walker方程,对应矩阵 ...
- C# FTP上传文件时出现"应 PASV 命令的请求,服务器返回了一个与 FTP 连接地址不同的地址。"的错误
FTP上传文件时出现"应 PASV 命令的请求,服务器返回了一个与 FTP 连接地址不同的地址."的错误 解决方法是在原代码上增加这句话 reqFTP.UsePassive = f ...
- SQLServer 将日期改造成标准日期格式(如: 2016/6 ->201606)
同事给了份Excel 数据,导到数据库之后再查出来时发现顺序不好弄.于是想从数据源中做处理. 由于数据存在,年/月 与 年/月/日 的格式不好用datetime保存,于是用varchar保存. 数据处 ...
- python2.7练习小例子(十七)
17):题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字.例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制. 程序分析: ...
- 20145202马超 2016-2017-2 《Java程序设计》第一次实验
之前做的(http://www.cnblogs.com/tuolemi/p/5707098.html) 其余的 断点的使用 行断点 条件断点 参考(http://www.cnblogs.com/roc ...
- NoSQL简单学习(一)
只是简单的知道有这个东西,却从来没有去接触,今天看了几篇文章,记录一下,开始慢慢接触这一领域 简介: 8种Nosql数据库系统对比 http://blog.jobbole.com/1344/ 一网打尽 ...
- jmeter插件下载
https://jmeter-plugins.org/wiki/Start/ 插件下载好后,将插件lib目录下的jar包放在jmeter安装目录下的lib里,插件ext目录下的jar包放在jmeter ...