我的编程空间,编程开发者的网络收藏夹
学习永远不晚

git中reset和revert的区别有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

git中reset和revert的区别有哪些

这篇文章主要介绍“git中reset和revert的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“git中reset和revert的区别有哪些”文章能帮助大家解决问题。

区别:1、reset是彻底回退到指定的commit版本,该commit后的所有commit都将被清除;而revert仅是撤销指定commit的修改,并不影响后续的commit。2、reset执行后不会产生记录,revert执行后会产生记录。

git是我们常用的版本管理工具,我们团队在合作开发项目时,时常会因为代码及文件的修改提交,导致各种各样的冲突,还有产品需求的频繁变更,致使我们不得不做出回退版本,撤回提交这样的决定,那么此时,reset和revert命令,就派上了用场!

reset,revert都有撤销、回退的意思,但却各有千秋,区别还是很大的,所以该使用哪种命令一定要结合实际情况来决定,本文就是带大家搞清楚两者的区别,然后能准确快速的使用正确的命令去解决实际问题!

下面的例子中,我有3次提交:初始状态,只有readme一个文件,内容为Creating a new branch is quick.t1提交后状态:只有readme一个文件,内容修改为Creating a new branch is quick 1.t2提交后状态:只有readme一个文件,内容修改为Creating a new branch is quick 1 2.t3提交后状态:新增了test文件.

本文以git bash为例:

git中reset和revert的区别有哪些

先说reset

reset,使用方法:git reset --hard commit ,commit是提交后产生的SHA1,执行该命令后,代码会完全回退到本次提交时的状态,工作暂存区以及本次提交后面的提交内容将会被完全清除,包括提交记录!

举例:

原项目,包含一个Readme.txt文件:
git中reset和revert的区别有哪些

文件内容:
git中reset和revert的区别有哪些

此时我将修改文件内容为:

Creating a new branch is quick 1.

进行第一次提交
git中reset和revert的区别有哪些

提交记录:
git中reset和revert的区别有哪些

提交后的远程仓库目录及文件内容:

git中reset和revert的区别有哪些
没有问题,继续修改文件内容:Creating a new branch is quick 1 2. ,进行第二次提交
git中reset和revert的区别有哪些

现在我将新增一个test文件,进行第三次提交
git中reset和revert的区别有哪些

git中reset和revert的区别有哪些

好了,现在产品需求变更了,新增的功能(readme的第二次修改和新增的test文件)不需要了,要求回退到第一次提交“t1”,如果我们选择使用reset:

首先定位到t1的commit,可以从远程仓库提交历史记录中复制,也可以用命令git log查看:

git中reset和revert的区别有哪些

(小提示,如果最后一行出现“:”,则输入wq退出回到命令行即可!)

复制commit,执行命令:

git reset --hard 8cbf16c0821d20fe42c361f4e3d75a0493dc5fc2

git中reset和revert的区别有哪些

提示,HEAD已经指向了t1,但你刷新后台时,发现并没有什么变化,这是因为我们还需要执行一下push,但这里需要注意的是,因为本地代码回到了旧版本,但远程仓库是新版本和本地不一致,所以你在用git push时会报错,这里我们需要使用强制提交,git push -f,我们也可以使用git status查看当前状态:

git中reset和revert的区别有哪些

意思是告诉你,远程仓库代码较新,需要你执行 git pull操作以同步代码,但这并不是我们的需求,所以我们不用理会,执行,git push -f

git中reset和revert的区别有哪些

再看仓库:

git中reset和revert的区别有哪些

历史记录只剩下了t1:

git中reset和revert的区别有哪些

readme内容也得到了恢复:

git中reset和revert的区别有哪些

可见,reset是彻彻底底的回退,该commit之后的所有修改将完全消失,包括提交记录。

优点

  • 彻底回退到指定版本,干净清爽;

  • 提交时间线清晰,没有冗杂;

缺点

  • 记录彻底清除,无法再次恢复;

再说revert

revert执行后会产生新的commit记录,是通过一次新的commit来恢复到之前旧的commit,但revert会保留恢复的该次提交后面的其它提交内容,假如后面的提交与要恢复的提交更改了同一地方,此时用revert就会产生冲突!

我们继续以上面的例子为例,我重新执行了t2和t3提交,恢复到reset之前的状态:

git中reset和revert的区别有哪些

此时,我们按reset的思路,使用revert恢复到t1,执行命令:

git revert 8cbf16c0821d20fe42c361f4e3d75a0493dc5fc2

报错:

git中reset和revert的区别有哪些

提示冲突了?让我们解决掉冲突后提交…

<<<<<<< HEADCreating a new branch is quick 1 2.=======Creating a new branch is quick.>>>>>>> parent of 8cbf16c (t1)

上面的冲突表示,当前的内容是:

Creating a new branch is quick 1 2.

而我们要恢复的内容是:

Creating a new branch is quick.

如果对revert命令没有深入了解的话,就可能会产生疑惑,为什么会冲突?而且我实际上是想像reset一样恢复或者说是回退到t1(这里要再次说明一下t1的状态:只有一个readme文件,且内容是Creating a new branch is quick 1),但为什么冲突提示要恢复到Creating a new branch is quick.???这不是初始状态吗?

其实,准确来说,revert是撤销/撤回/反提交的意思,我们不能按reset的思路理解,我们执行git revert t1,这么做其实结果是要撤销t1的提交,注意,仅仅是撤销t1的提交,把t1的修改恢复到t1之前也就是初始的状态,而不会影响t2,t3的提交。但如果t2,t3中修改了t1修改的同一地方,那么就会产生冲突,因为revert意图撤销t1的修改,但发现t2和t3把t1的修改再次修改了,此时,revert意图变得不清晰,因为它无法确定到底是应用你最新的修改,还是恢复到初始状态,这将由你来决定!

所以我们想要恢复t1的状态,那我们就应该撤销t2对t1的修改git revert t2

git revert fc4889dcb327cff9f8078db6a0d5c601b8e91ae9

执行后会自动进入编辑界面:

git中reset和revert的区别有哪些

这里需要我们修改或输入提交日志,按 “i”,进入输入状态,写完后按ESC退出输入状态,再按“:wq”退出!

成功后,执行 git push:

git中reset和revert的区别有哪些

查看仓库后台:

git中reset和revert的区别有哪些

项目目录:

git中reset和revert的区别有哪些

readme内容:

git中reset和revert的区别有哪些

可见,revert操作成功后,产生了新的commit记录,t2对t1的修改已经恢复,现在的readme就是t1提交后的状态,但同时test文件仍然存在,即t3的提交不受影响!

但如果你说,想要和reset一样,把t2t3的提交也要删除掉,那你就先revert t3,再revert t2,可以达到同样的效果,但这样一来,为何不直接用reset?如果你说既想达到reset的效果,又想有记录防止反悔,那这。。。是一个值得思考的问题!

git reset和revert区别的总结:

  • reset是彻底回退到指定的commit版本,该commit后的所有commit都将被清除,包括提交历史记录;

  • revert仅仅是撤销指定commit的修改,并不影响后续的commit,但所撤销的commit被后续的commit修改了同一地方则会产生冲突;

  • reset执行后不会产生记录,revert执行后会产生记录;

  • reset执行后无法再次恢复,revert执行后因为不会清除记录,并且会产生新纪录,所以文件不会丢失,你可以多次执行revert恢复到某次改变之前的状态;

  • reset执行后HEAD会后移,而revert的HEAD则一直是向前的;

理清了reset和revert的基本原理,你就明白了在什么时间该使用哪个命令更为合适了!

小提示:在IDEA开发工具中,选中一个文件,右键git选项中会发现有一个Rollback

git中reset和revert的区别有哪些

这里需要跟reset和revert区分一下,rollback并不属于git命令,它的作用是,在文件或代码修改后,但还未commit,想恢复到与远程仓库代码一致的状态,便可以执行rollback操作!

关于“git中reset和revert的区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

git中reset和revert的区别有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

git中reset和revert的区别有哪些

这篇文章主要介绍“git中reset和revert的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“git中reset和revert的区别有哪些”文章能帮助大家解决问题。区别:1、reset
2023-06-21

git revert和git reset有什么区别

这篇文章将为大家详细讲解有关git revert和git reset有什么区别,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。git revert和git reset的区别git revert 是生成一个新
2023-06-09

git revert和git reset的区别详解

git revert和git reset的区别 git revert 是生成一个新的提交来撤销某次提交,此次提交之前的commit都会被保留git reset 是回到某次提交,提交及之前的commit都会被保留,但是此次之后的修改都会被退回
2022-06-04

Git Reset和Git Revert命令有什么区别

这篇文章主要为大家展示了“Git Reset和Git Revert命令有什么区别”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Git Reset和Git Revert命令有什么区别”这篇文章吧。
2023-06-15

git中rebase和merge的区别有哪些

本篇内容介绍了“git中rebase和merge的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!区别:1、rebase把当前的co
2023-06-26

gitlab和git的区别有哪些

这篇文章主要讲解了“gitlab和git的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“gitlab和git的区别有哪些”吧!gitlab和git的区别:Git是一种版本控制系统,
2023-06-21

git和npm的区别有哪些

git和npm的区别有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。区别:1、Git是一个开源的分布式版本控制系统,而npm是以JavaScript编写的软
2023-06-22

git和github的区别有哪些

随着计算机技术的迅猛发展,团队协作成为了一种业界标准。而版本控制则成为协作的一个重要方面。版本控制工具有很多,其中Git是广泛使用的一个版本控制工具,而GitHub则是Git的一个云端服务。对于初学者来说,理解Git和GitHub的区别是非
2023-10-22

git中pull和fetch的区别有哪些

这篇“git中pull和fetch的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“git中pull和fetch的区
2023-06-26

git中push和pull的区别有哪些

这篇“git中push和pull的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“git中push和pull的区别有
2023-06-26

git和github有哪些区别

本篇内容介绍了“git和github有哪些区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git和github的区别:1、git是一个版本
2023-06-21

git和gerrit有哪些区别

本篇内容介绍了“git和gerrit有哪些区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git和gerrit的区别:1、Git是一种版本
2023-06-21

git和tortoisegit有哪些区别

这篇文章给大家分享的是有关git和tortoisegit有哪些区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。区别:1、git是一个开源的分布式版本控制系统,用于处理项目版本管理,而tortoisegit是To
2023-06-26

git的tag和branch有哪些区别

本篇内容主要讲解“git的tag和branch有哪些区别”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“git的tag和branch有哪些区别”吧!区别:1、tag是一系列commit的中的一个点
2023-06-21

git下commit和push的区别有哪些

这篇文章主要介绍git下commit和push的区别有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!区别:“git commit”命令是将本地修改过的文件提交到本地库中,而“git push”命令是将本地库中的最
2023-06-21

git推送和提交的区别有哪些

本篇内容介绍了“git推送和提交的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git推送和提交的区别:1、推送(push)指的是
2023-07-02

git与tfs的区别有哪些

本篇内容介绍了“git与tfs的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git与tfs的区别:1、tfs是应用程序生命周期管
2023-06-26

git与tfs有哪些区别

这篇文章主要介绍了git与tfs有哪些区别的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇git与tfs有哪些区别文章都会有所收获,下面我们一起来看看吧。区别:1、TFS是应用程序生命周期管理解决方案,而Git仅
2023-06-26

Kotlin中?和!!的区别有哪些

这篇文章给大家分享的是有关Kotlin中?和!!的区别有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言很多同学刚上手使用Kotlin知道它有针对Java NullPointerException的管理,而
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录