iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >git中reset和revert的区别有哪些
  • 942
分享到

git中reset和revert的区别有哪些

2023-06-21 22:06:09 942人浏览 泡泡鱼
摘要

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

这篇文章主要介绍“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的区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: git中reset和revert的区别有哪些

本文链接: https://www.lsjlt.com/news/300948.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • git中reset和revert的区别有哪些
    这篇文章主要介绍“git中reset和revert的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“git中reset和revert的区别有哪些”文章能帮助大家解决问题。区别:1、reset...
    99+
    2023-06-21
  • git revert和git reset有什么区别
    这篇文章将为大家详细讲解有关git revert和git reset有什么区别,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。git revert和git reset的区别git revert 是生成一个新...
    99+
    2023-06-09
  • Git Reset和Git Revert命令有什么区别
    这篇文章主要为大家展示了“Git Reset和Git Revert命令有什么区别”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Git Reset和Git Revert命令有什么区别”这篇文章吧。...
    99+
    2023-06-15
  • git中rebase和merge的区别有哪些
    本篇内容介绍了“git中rebase和merge的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!区别:1、rebase把当前的co...
    99+
    2023-06-26
  • git中push和pull的区别有哪些
    这篇“git中push和pull的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“git中push和pull的区别有...
    99+
    2023-06-26
  • git中pull和fetch的区别有哪些
    这篇“git中pull和fetch的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“git中pull和fetch的区...
    99+
    2023-06-26
  • git和github的区别有哪些
    随着计算机技术的迅猛发展,团队协作成为了一种业界标准。而版本控制则成为协作的一个重要方面。版本控制工具有很多,其中Git是广泛使用的一个版本控制工具,而GitHub则是Git的一个云端服务。对于初学者来说,理解Git和GitHub的区别是非...
    99+
    2023-10-22
  • gitlab和git的区别有哪些
    这篇文章主要讲解了“gitlab和git的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“gitlab和git的区别有哪些”吧!gitlab和git的区别:Git是一种版本控制系统,...
    99+
    2023-06-21
  • git和npm的区别有哪些
    git和npm的区别有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。区别:1、Git是一个开源的分布式版本控制系统,而npm是以JavaScript编写的软...
    99+
    2023-06-22
  • git和tortoisegit有哪些区别
    这篇文章给大家分享的是有关git和tortoisegit有哪些区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。区别:1、git是一个开源的分布式版本控制系统,用于处理项目版本管理,而tortoisegit是To...
    99+
    2023-06-26
  • git和github有哪些区别
    本篇内容介绍了“git和github有哪些区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git和github的区别:1、git是一个版本...
    99+
    2023-06-21
  • git和gerrit有哪些区别
    本篇内容介绍了“git和gerrit有哪些区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git和gerrit的区别:1、Git是一种版本...
    99+
    2023-06-21
  • git的tag和branch有哪些区别
    本篇内容主要讲解“git的tag和branch有哪些区别”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“git的tag和branch有哪些区别”吧!区别:1、tag是一系列commit的中的一个点...
    99+
    2023-06-21
  • 使用Git和SVN的区别有哪些
    这篇文章主要介绍“使用Git和SVN的区别有哪些”,在日常操作中,相信很多人在使用Git和SVN的区别有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”使用Git和SVN的...
    99+
    2024-04-02
  • git下commit和push的区别有哪些
    这篇文章主要介绍git下commit和push的区别有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!区别:“git commit”命令是将本地修改过的文件提交到本地库中,而“git push”命令是将本地库中的最...
    99+
    2023-06-21
  • git与tfs的区别有哪些
    本篇内容介绍了“git与tfs的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git与tfs的区别:1、tfs是应用程序生命周期管...
    99+
    2023-06-26
  • git推送和提交的区别有哪些
    本篇内容介绍了“git推送和提交的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!git推送和提交的区别:1、推送(push)指的是...
    99+
    2023-07-02
  • git与tfs有哪些区别
    这篇文章主要介绍了git与tfs有哪些区别的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇git与tfs有哪些区别文章都会有所收获,下面我们一起来看看吧。区别:1、TFS是应用程序生命周期管理解决方案,而Git仅...
    99+
    2023-06-26
  • normalize和css reset有什么区别
    这篇文章主要介绍“normalize和css reset有什么区别”,在日常操作中,相信很多人在normalize和css reset有什么区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2024-04-02
  • js中==和===的区别有哪些
    这篇文章将为大家详细讲解有关js中==和===的区别有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript是什么JavaScript是一种直译式的脚本语言,其解释器被称为JavaScri...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作