git reset和git revert的区别

news2024/11/18 10:46:29

前提条件

假设现在有三次提交到remote repository:

commit abf94bdf743e23737950c36bda381d2aba1803fc(HEAD -> master, origin/master)
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:36:39 2021 +0800

    feat add 3.go

commit 181cc7131acc18f248aba4638439054e886d695a
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:36:09 2021 +0800

    feat add 2.go

commit 75cbe2918cb11e444be085da6890c6d3ecfd71eb
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:35:16 2021 +0800

    feat add 1.go

git reset --hard 命令

git reset 重置的是HEAD指针,是把HEAD指向指定的commit,此指定的commit之后的所有提交都不存在,也不会留下任何的痕迹!!!!!!!!!
如,使用git reset --hard命令:

	git reset --hard 75cbe2918cb11e444be085da6890c6d3ecfd71eb #第一次提交的commit id,此时HEAD指针位于第一次提交的地方

使用git log查看提交日志时,如下:

	git log
	commit 75cbe2918cb11e444be085da6890c6d3ecfd71eb
	Author: ztenv <class7class@qmm.com>
	Date:   Tue Sep 21 16:35:16 2021 +0800

    feat add 1.go

此只仅仅重置了本地的HEAD,还需要将期强推到remote,如下:

	git push origin --force

上面的命令执行成功后,可以看到远端只能看到commit了一次,第2、3次的提交已经不存在了

特别注意:这种操作一但发生成,不可逆的(除非在队友没有更新的前提下使用他本地的repository恢复),也不会留下任何的痕迹!!!!总之,慎之又慎吧。

git revert 命令

git revert命令是用来**revert(恢复)**某一个commit提交的内容的(不会影响其他的commit),可以理解为是某一次commit的逆运算(即:把增加的删除、把删除的加回来,做一次commit的逆运算), git revert commit_id成功之后,会生产一次新的提交,并且commit_id的影响将不会存在于git revert之后的commit,但是在git revert之前的commit中还是能看得到commit_id的改动的(有点乱,。。。。。)

如果revert的commit被后续的commit所依赖,那么会产生编译错误,如:commit20依赖了commit5声明的变量,当revert commit5之后,就会导致commit20编译失败)

如上面提前条件所示,如果想删除 2.go而保留1.go和3.go,revert的命令如下:

	git revert 338bf3e30983d34074f37a18b3ff80ea9bca75f0  # 第二次commit的id

执行上面的命令后,已经revert(恢复)了第二次commit的影响(第二次commit增加了2.go,revert而进行逆运算——删除2.go),并且多了一次commit(现在有4次commit了),使用git log得到如下结果:

commit 75cbe2918cb11e444be085da6890c6d3ecfd71eb (HEAD->master, origin/master)
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:40:39 2021 +0800

	Revert "feat add 2.go"
    This reverts commit 181cc7131acc18f248aba4638439054e886d695a

commit abf94bdf743e23737950c36bda381d2aba1803fc
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:36:39 2021 +0800

    feat add 3.go

commit 181cc7131acc18f248aba4638439054e886d695a
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:36:09 2021 +0800

    feat add 2.go

commit 75cbe2918cb11e444be085da6890c6d3ecfd71eb
Author: ztenv <class7class@qmm.com>
Date:   Tue Sep 21 16:35:16 2021 +0800

    feat add 1.go

git reset和git revert都是属于重新恢复工作区以及远程提交的方式,但这两种操作有着截然不同的结果:

git reset

是将之前的提交记录全部抹去,将 HEAD 指向自己重置的提交记录,对应的提交记录都不复存在;
在这里插入图片描述

git revert

操作是将选择的某一次提交记录 重做,若之后又有提交,提交记录还存在,只是将指定提交的代码给清除掉。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/492634.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023年值得关注:邮件营销平台的新技术和新趋势

对于希望增加在线影响力和想要接触更广泛受众的企业来说&#xff0c;电子邮件营销是一个非常好用的工具。它能够为企业培养长期的联系人&#xff0c;以极高的投资回报比为企业带来长期收益。特别是对于想要出海的企业或者做跨境贸易的公司来讲&#xff0c;邮件营销可以发挥巨大…

(抄送列表,年会抽奖)笔试强训

博主简介&#xff1a;想进大厂的打工人博主主页&#xff1a;xyk:所属专栏: JavaEE初阶 目录 文章目录 一、[编程题]抄送列表 二、[编程题]年会抽奖 一、[编程题]抄送列表 链接&#xff1a;抄送列表__牛客网 来源&#xff1a;牛客网 题目&#xff1a; NowCoder每天要处理许多邮…

Swift 技术 删除缓存,清空缓存

一直觉得自己写的不是技术&#xff0c;而是情怀&#xff0c;一个个的教程是自己这一路走来的痕迹。靠专业技能的成功是最具可复制性的&#xff0c;希望我的这条路能让你们少走弯路&#xff0c;希望我能帮你们抹去知识的蒙尘&#xff0c;希望我能帮你们理清知识的脉络&#xff0…

测试开发如何进阶?需要哪些能力?吐血整理-你的进阶之路...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 测试开发&#xff…

Redis底层设计与源码分析(一)__底层数据结构逻辑分析

前言 最近在工作中接触redis&#xff0c;但实际应用不多&#xff0c;可用场景也不是很明确&#xff0c;所以想借机多多学习下redis相关知识&#xff0c;一下内容都是通过自己找资源学习之后归纳总结的知识&#xff0c;若有相关错误点&#xff0c;请指正。 一、redis介绍 1.…

Softing线上研讨会 | 轻松访问XML文件中的过程数据

| 线上研讨会时间&#xff1a;2023年5月8日下午4点或晚上10点 对于传统车间的系统应用和创新的物联网解决方案而言&#xff0c;高效访问机器和流程数据至关重要。而在现有工厂中&#xff0c;过程数据通常以XML文件的形式出现。对此&#xff0c;Softing Industrial提供了一个用…

操作系统——设备管理

0.关注博主有更多知识 操作系统入门知识合集 目录 1.设备管理概念 2.SPOOLing技术 1.设备管理概念 在计算中&#xff0c;除CPU、内存以外的所有设备统称为外设&#xff0c;即外部设备&#xff0c;例如鼠标、键盘、打印机、摄像头、磁盘、硬盘......那么这些只需要连接到计…

多城市门店店铺展示地图导航pc/h5系统开发

多城市门店店铺展示地图导航pc/h5系统开发 系统设置&#xff1a; 网站标题、网站副标题、Logo图、网站背景图、网站底部图、网站底部版权、网站ICP备案、腾讯地图Key。 店铺列表&#xff1a; 店铺名称、店铺图标、设备、电话、省市区、详细地址。 添加店铺&#xff1a; 店铺…

搭建Harbor镜像仓库及简单使用

一、Harbor简介 Harbor是由VMware公司中国团队为企业用户设计的Registry server开源项目&#xff0c;包括了权限管理(RBAC)、LDAP、审计、管理界面、自我注册、HA 等企业必需的功能&#xff0c;同时针对中国用户的特点&#xff0c;设计镜像复制和中文支持等功能。 作为一个企…

CentOS7下离线安装MySQL8

背景 在hw外包干久了&#xff0c;要废了&#xff0c;什么都要忘记了&#xff0c;感觉和外面脱节太大了&#xff0c;太危险了&#xff0c;赶紧复习一下压压惊。 准备rpm安装包 下载地址&#xff1a;https://www.mysql.com/cn/downloads/ 图1&#xff1a; 图2&#xff1a; 图…

2 行代码开启 SAST,将代码漏洞定位到具体行数

&#x1f4a1; 如何在流水线中集成与应用 SAST&#xff0c;实现自动化代码安全扫描 &#xff1f; 近日&#xff0c;在「DevSecOps软件安全开发实践」课程上&#xff0c;极狐(GitLab) 高级专业服务交付工程师欧阳希、极狐(GitLab) 后端工程师黄松&#xff0c;分享了静态安全扫描…

互联网赚钱项目有哪些?目前最火的互联网项目

互联网是一个神奇的行业&#xff0c;大门不出二门不迈&#xff0c;一根网线一台电脑&#xff0c;甚至一台手机就可以赚钱。它给我们创造了前所未有的商业机会&#xff0c;让成千上万有梦想&#xff0c;敢想敢干的人通过互联网获得了巨大的成功&#xff01;正因为如此&#xff0…

引领真无线耳机未来趋势,NANK南卡OE骨传导真无线耳机惊艳亮相

传统的蓝牙耳机存在很多问题&#xff0c;例如续航时间短、长期佩戴耳朵会不舒服&#xff0c;甚至影响听力等等。为了解决这些问题&#xff0c;在骨传导领域深耕十多年的南卡品牌推出了这款真无线骨传导耳机——NANK南卡 OE。 NANK南卡OE即将正式上线&#xff0c;这一消息一经宣…

项目搭建第一天后台搭建方式

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、后台环境是什么&#xff1f;二、使用步骤1.项目目录2.项目介绍3.项目构建3.1 注册中心搭建方式3.2 关键配置3.3 开启高可用方式 总结 前言 提示&#xff1…

10 KVM虚拟机配置-虚拟CPU和虚拟内存

文章目录 10 KVM虚拟机配置-虚拟CPU和虚拟内存10.1 概述10.2 元素介绍10.3 配置示例 10 KVM虚拟机配置-虚拟CPU和虚拟内存 10.1 概述 本节介绍虚拟CPU和虚拟内存的常用配置。 10.2 元素介绍 vcpu&#xff1a;虚拟处理器的个数。 memory&#xff1a;虚拟内存的大小。 属性un…

盖雅工场荣获「2022年度最佳人力资源服务机构」奖

2023年4月26日&#xff0c;HRoot重磅发布2022年度最佳人力资源服务机构榜单。盖雅工场凭借专业的服务、优质的品牌口碑和影响力&#xff0c;再度荣获「2022年度最佳人力资源服务机构」奖项&#xff0c;彰显了盖雅优秀的产品实力以及在人力资源技术服务领域的优势地位。 奖项背景…

PCL学习五:Range Images-距离图像

参考引用 Point Cloud Library黑马机器人 | PCL-3D点云PCL深度图像 1. 引言 1.1 深度图像的获取与研究方向 获取方法 激光雷达深度成像法&#xff0c;计算机立体视觉成像&#xff0c;坐标测量机法&#xff0c;莫尔条纹法&#xff0c;结构光法 研究方向 深度图像的分割技术深度…

使用 SaleSmartly 实时聊天提高转化率

在竞争激烈的电子商务环境中&#xff0c;很难给客户留下持久的印象&#xff0c;与他们建立关系更加困难。但是&#xff0c;提供个性化的体验和产品是超越竞争对手的最佳方式之一。这就是为什么许多跨境电子商务企业将与客户的个性化沟通作为他们的首要任务。 SaleSmartly&#…

JVM原理与实战(一)

jvm的基本结构 1.类加载系统 负责从文件系统或者网络中加载Class信息 2.方法区 &#xff08;1&#xff09;加载的类信息存放于一块称为方法去的内存空间 &#xff08;2&#xff09;除了类的信息外&#xff0c;方法区中可能还存放着运行时常量池信息&#xff0c;包括字符串字面…

PyQt5桌面应用开发(8):从QInputDialog转进到函数参数传递

本文目录 PyQt5桌面应用系列How old are you, Dialog?QInputDialog minimalistwhy not lambdaand how partial worksSummary PyQt5桌面应用系列 PyQt5桌面应用开发&#xff08;1&#xff09;&#xff1a;需求分析 PyQt5桌面应用开发&#xff08;2&#xff09;&#xff1a;事件…