本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/git_code_roll_back_revert_and_reset

reset

某些特殊的情况下,需要回退到先前的某一次提交。

git log 查找想要回退的commit的id后运行:

git reset --hard 2c1e288

回退后git log只会显示回退版本之前的提交。如果需要返回最新的提交,使用git reflog查看对应的id。

git reset只适合本地的回退和查看先前代码。如果远程仓库已有最新的提交,git会认为远程仓库的代码较新,需要先同步远程代码再进行修改,此情况下建议使用revert。

git reset –soft –mixed –hard

HEAD~为例(HEAD前的一次提交)

git reset --soft HEAD~ 会回到前一次提交的commit执行之前的状态
git reset --mixed HEAD~ 会回到前一次提交的add执行之前的状态
git reset --hard HEAD~ 会回到前一次提交的add执行之前的状态,并且将目录里的所有文件调整为前一次的提交状态

通常回退时需要将文件也回退需要加 –hard 标签。

git的文件组织

git将所有的文件以hash码命名放在仓库中存储。

HEAD指针,一般可以理解为当前commit状态的一个快照(指向仓库中当前commit的所有的文件)。每次commit或者merge等会创建新的commit节点时,会让HEAD指向新的位置。

reset会改变HEAD指针的位置与HEAD对应的分支指针的位置,checkout只会改变HEAD指针指向的分支。

revert

git revert <commit-id> 相当于取消一次commit ,会让结果和没有这一次提交一样,并非像reset那样直接回到某一次commit的代码。

使用revert不会破坏历史记录,只是提交一个新的修改使修改后代码和以前一致。

实质上相当于用前的代码merge 后的代码,因此如果后面对代码文件做了修改需要解决冲突。

revert一个merge commit

注意revert用在merge的commit上的情况有坑

git revert <commit-id> -m 1 需要添加-m参数,指定是merge前的第几个分支(git log上的merge后)。

revert的主要麻烦:如果存在分支合并的情况,如下,从m1 revert到a2时会添加一个新的提交m2,当m2与b2 merge时会显示已经merge过

a1 -> a2 -> m1 -> m2
b1 -> b2 /

因此在两个分支还需要合并时,不能直接使用merge,而要先revert上一次的revert,让两次revert抵消,也就是 git revert <m2 commit id>

为了少折腾,碰到两个分支以后注定还是要合并的情况,还是不要revert了吧,或者revert之后改完相应的代码就revert回来,貌似没人提到更好的解决方案….

不常用的回退

以下命令存在危险性不建议使用,而且一般也没有使用必要。注意某些操作针对未提交前的处理,可能导致对文件修改的丢失。git对已提交的文件几乎总是可以恢复的,因此建议尽量在提交后处理。

git checkout <file> 撤销文件修改(到上一次提交)。
git commit --amend 重新提交,提交后删除上一次提交。

git 代码回滚与爬坑 -- reset and revert的更多相关文章

  1. git的回滚与撤销【reset and revert】

    git的工作流程-- 3个区域 工作区:我们可以看到的文件内容 在操作 git add 之前的!! 缓存区:是不可见的  已经git add操作,还没git commit -m "" ...

  2. git代码回滚:Reset、Checkout、Revert的选择

    代码回滚:Reset.Checkout.Revert的选择 Zhongyi Tong edited this page on Dec 8, 2015 · 5 revisions Pages 19 Ho ...

  3. 6.Git代码回滚

    1.代码修改并提交 我们已经成功地添加并提交了一个helloWorld.txt文件,现在,是时候继续工作了. 于是,我们继续修改helloWorld.txt文件,改成如下内容: $ vi helloW ...

  4. git代码回滚的两种选择

    回滚到指定commit,且保持该commit之前和之后的提交记录 使用git revert命令. git revert HEAD // 回滚到前一次 commit git revert HEAD^ / ...

  5. git代码回滚

    有时候我们用git提交代码后发生了错误,代码冲突了啊等等,我们需要将代码回到以前的某个版本 git代码回退有两种办法 一.git reset(推荐): 它是将最新的commit删除,用以前的某个版本的 ...

  6. 转一篇Git代码回滚技巧

    转 https://github.com/geeeeeeeeek/git-recipes/wiki/5.2-代码回滚:Reset.Checkout.Revert的选择

  7. Git如何回滚代码?

    摘要: 多年以后,你面对一个需要回滚的Git仓库,准会想起这篇博客. 某一天,用户跟我反馈,他不能分配任务了.我去看了一下Fundebug捕获的报错信息: 可知,出错原因是前端发送的请求参数有问题.这 ...

  8. 代码回滚:Reset、Checkout、Revert的选择

    代码回滚:Reset.Checkout.Revert的选择 Git仓库有三个主要组成——工作目录,缓存区和提交历史. 从图中我们可以看出,缓存区或者叫索引,其实是指一整套即将被下一个提交的文件集合.也 ...

  9. Git撤销&回滚操作(git reset 和 get revert)

    转自:https://blog.csdn.net/asoar/article/details/84111841 git的工作流 工作区:即自己当前分支所修改的代码,git add xx 之前的!不包括 ...

随机推荐

  1. TCP(上)

    tcp头格式: TCP状态位: SYN表示建立连接, FIN表示关闭连接, ACK表示响应, PSH表示有 DATA数据传输, RST表示连接重置. TCP窗口: TCP 要做流量控制,通信双方各声明 ...

  2. CCF 2017-03-1 分蛋糕

    CCF 2017-03-1 分蛋糕 题目 问题描述 小明今天生日,他有n块蛋糕要分给朋友们吃,这n块蛋糕(编号为1到n)的重量分别为a1, a2, -, an.小明想分给每个朋友至少重量为k的蛋糕.小 ...

  3. 在论坛中出现的比较难的sql问题:16(取一个字段中的数字)

    原文:在论坛中出现的比较难的sql问题:16(取一个字段中的数字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路. 问题:取一个字段中的数字http://bbs.csdn ...

  4. ExcelReport.cs Excel操作类、实例源码下载

    标题一.告别ASP.NET操作EXCEL的烦恼标题二.ASP.NET操作EXCEL 合并单元格 大全... cnblogs/hanzhaoxin/韩兆新的博客园ExcelReport第一篇:使用Exc ...

  5. 使用async和await的异步编程

    异步编程模型(TAP)提供了抽象的异步代码.异步代码看起来和同步代码没什么大的区别,无非多个了两个关键字(async和await).但是代码的执行顺序并没看起来那么简单,代码的执行顺序根据cpu资源的 ...

  6. 转 无损转换Image为Icon

    不可取 var handle = bmp.GetHicon();    //得到图标句柄return Icon.FromHandle(handle); //通过句柄得到图标 可取 /// <su ...

  7. Bootstrap4 入门

    http://www.runoob.com/bootstrap4/bootstrap4-navs.html 共五个部分 1 <!DOCTYPE html> <html lang=&q ...

  8. 数据结构之队列(queue)

    队列介绍 1.队列是一个有序列表,可以用数组或是链表来实现. 2.遵循先入先出的原则.即:先存入队列的数据,要先取出.后存入的要后取出. 应用场景 比如某某银行叫号系统: 数组模拟队列 队列本身是有序 ...

  9. HTML5页面介绍

    1.<!DOCTYPE html>     文档声明:用于告诉浏览器使用html哪个版本的标准解析页面,此写法代表使用html5的标准去解析 2.<html>     根标签, ...

  10. IO模型之NIO代码及其实践详解

    一.简介 NIO我们一般认为是New I/O(也是官方的叫法),因为它是相对于老的I/O类库新增的( JDK 1.4中的java.nio.*包中引入新的Java I/O库).但现在都称之为Non-bl ...