[git]撤销的相关命令:reset、revert、checkout

基本概念

  1. 工作区
  2. 暂存区
  3. 本地版本仓库
  4. 远程版本仓库

如果不清晰上面的四个概念,请查看廖老师的git教程

这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改 存起来。后来用多了,也就明白了为什么。git是一个“版本管理工具”,大家在写东西的时候都用过“回撤” 这个功能,但是回撤只能回撤几步,假如想要找回我三天之前的修改,光用“回撤”是找不回来的。而“版本管理工具” 就是记录每次的修改,只要提交到版本仓库,你就可以找到之前任何时刻的状态(文本状态)。

当然,上面我只说了一部分git的好处,只为后面的东西作为铺垫。因为,后面会说到三个关于git上面如何“反悔”、 “回到任意时候的代码”,其实就是上面说的原始的“回撤”升级版,版本管理工具的“回撤”。

checkout、reset、revert这三个指令

  • checkout:清空工作区的修改
    • 清空工作区的修改git checkout changed_file,清空所有工作区的修改git checkout .
    • 切换分支git checkout branch_name(在切换分支之前,需要清空工作区,提交到本地版本仓库或者移除工作区的东西)
    • 快速查看某个版本的代码git checkout commit_id/HEAD~last_version_num,切换到一个临时分支,内容就是指定的版本内容
  • reset:撤销某次提交(commit),并把这次提交的所有修改放到工作区
    • git reset HEAD~last_version_num/commit_id,注意:这个操作修改历史,所以push到 远程仓库会出现问题,可以通过-f参数,实现强制推送。
  • revert:回到之前的某个版本的状态,并创建一个新的提交。
    • git revert HEAD~last_version_num/commit_id,创建一个新的commit,该内容为指定的 版本的内容,注意:这个操作并不会重写历史,也就是原来的commit还是存在的。

git reset 和git revert的区别: git revert是用一次新的commit来回滚之前的commit,git reset是直接删除指定的commit。 git reset 是把HEAD向后移动了一下,而git revert是HEAD继续前进

在回滚这一操作上看,虽然效果差不多,但是日后继续merge以前的老版本时有区别。因为git revert是用一次逆向的commit“中和”之前的提交,因此日后合并老的branch时,导致这部分改变不会再次出现,但是git reset是之间把某些commit在某个branch上删除,因而和老的branch再次merge时,这些被回滚的commit应该还会被引入。

原文发布于微信公众号 - 我为Net狂(dotNetCrazy)

原文发表时间:2016-08-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏架构师小秘圈

服务优化指南

2733
来自专栏后台经验

现网gc问题定位三板斧

国庆假期临近,组里的小伙伴们都开开心心请假回家了,然后cgi很应景的出现了多台机器的频繁full gc,所以只能上阵用力撸一把了。

3714
来自专栏SDNLAB

如何向OpenDaylight社区贡献代码

本文由两部分构成,第一部分简要介绍了Gerrit的工作原理以工作流程,第二部分结合自己成功提交代码的例子,向大家展示向OpenDaylight提交源码的过程。向...

3759
来自专栏腾讯云数据库团队的专栏

Hbase WAL 线程模型源码分析

Hbase的WAL机制是保证hbase使用lsm树存储模型把随机写转化成顺序写,并从内存read数据,从而提高大规模读写效率的关键一环。wal的多生产者单消费者...

6.1K3
来自专栏喔家ArchiSelf

老码眼中的Git

Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。大神就是大神,在开发了Linux之后,Git 是...

1052
来自专栏PhpZendo

深入浅出 Laravel 的 Facade 外观系统

本文将从以下几个方面出发,全面讲解 Laravel 中 Facade 的运行原理,为了便于理解后续中所有 Facade 译作「外观」:

2291
来自专栏Spark学习技巧

HBase原理和设计

作者:Jiang Hongxiang 来源:比特科技 简介 HBase —— Hadoop Database的简称,Google BigTable的另一种开...

41110
来自专栏编程

我是如何利用CSRF Get DedeCms Shell的

说实话,有一两个月没有审计大厂了,然后随便看到群里有人问dede最新有没有漏洞,就下了一套最新的dede,结果我一看还真发现了。 ? 我们发现后台添加广告的地方...

2107
来自专栏互联网高可用架构

教你如何成为Java的OOM Killer

1895
来自专栏bboysoul

linux 终端下最简单的代理方式(proxychains)

我以前写过给linux终端设置代理 这个是用polipo这个工具把socks5代理转换成为http和https代理来实现终端下代理的,那么终端下有没有原生的使...

1672

扫码关注云+社区

领取腾讯云代金券