【git 使用】超级好用的 git reset 和 git revert 功能对比和使用方法

首先你要知道 git 区分暂存区和工作区,如果你用过 sourcetree 你就会知道

git reset 超级好用

git reset 命令用于将当前分支的 HEAD 指针移动到指定的提交,并且可以选择性地修改工作区和暂存区的状态。git reset 命令有几种常用的用法,主要包括:

  1. git reset --soft <commit-id>: 被 reset 的提交会放到暂存区,暂存区原来的内容不会变化,同时不影响工作区;这个选项通常用于撤销之前的提交,但保留更改以供稍后提交。        
    1. 可以通过 git log 查看 id,git 基于指定的提交 id 来移动 head 指针,并且撤销这个提交之后的所有更改
    2. 可以使用 head 替换提交 id 代表撤销最近一次提交
  2. git reset --mixed head~n:  清空暂存区,被 reset 的提交会放到工作区,并和当前工作区的改动进行合并,有相同的改动,以工作区的改动为准,即不改动工作区的状态;这意味着之前的提交所做的更改都会被放到工作区。【reset 不增加参数, 默认使用mixed
    1. n 代表相对于你当前 head 指针的偏移量
    2. 可以是任何数字,1 代码最近一次提交,2 代码最近 2 次提交,以此类推
    3. 但是 n 如果大于所有提交的数量,就会报错
    4. 不可以不写 ~n,至少是 ~1,不信你试试
    5. 可以使用这个 reset 命令 撤销 git add 的操作,也就是把暂存区的文件放回工作区
  3. git reset --hard head~n: reset 之后暂存区和工作区状态都会被清空,会丢弃之前的提交的内容,所以不要用!!很危险,除非使用 git reflog 能找回来,但是 git reflog 有保存期限,时间久了 reflog 的内容也会清理,所以就永远找不到了。

git revet 功能

git revert 命令用于撤销一个或多个提交所做的更改,并创建一个新的提交来记录撤销的操作

  1. git log: 使用 git log 查看提交历史,确定需要撤销的提交的ID
  2. git revert <commit-id>:指定要撤销的提交 ID,会创建一个新提交并将所做的更改撤销掉
    1. :
  3. git revert head: 撤销最近一次提交
  4. git revert <commit-id1>..<commit-id2> :撤销多个提交,可以指定一个范围
  5. 解决冲突(如果有): 在执行 git revert 命令时,如果发生了冲突(例如,撤销的提交与当前分支上的其他更改冲突),Git 会提示你解决冲突。解决完冲突后,可以使用 git add 命令将解决后的文件标记为已解决,然后执行 git revert --continue 完成撤销操作。
  6. 提交撤销的更改: 最后,执行 git revert --continue 完成撤销操作,并将撤销的更改作为一个新的提交提交到仓库中。
  7. 如果你不想继续撤销操作,可以执行 git revert --abort 命令来取消撤销操作。

使用 git revert 命令可以安全地撤销提交,并且不会修改提交历史,因此适合在公共分支上使用。

git reset 和 git revert 对比

  1. git reset:

    • git reset 主要用于修改分支的 HEAD 指针,可以将分支的 HEAD 指针移动到指定的提交,并且可以选择性地修改暂存区和工作区的状态。
    • git reset 常用于本地分支操作,它会修改分支的提交历史,因此在团队协作中应谨慎使用,避免造成提交历史混乱。
    • git reset 通常用于撤销已提交的更改,或者将暂存区和工作区的状态回退到之前的状态。
  2. git revert:

    • git revert 用于撤销一个或多个提交所做的更改,并且会创建一个新的提交来记录撤销的操作。
    • git revert 不修改分支的提交历史,而是在原来的提交历史上创建一个新的撤销提交,因此它更适合用于公共分支上的撤销操作,不会影响其他开发者的提交历史。
    • git revert 通常用于撤销已经发布到公共分支的提交,或者撤销错误的提交并保留提交历史的完整性。

总的来说,git reset 用于修改分支的提交历史和工作区状态,而 git revert 用于创建一个新的撤销提交来记录撤销的操作,不修改提交历史。选择使用哪个命令取决于具体的情况和需求。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JPCS出版|EI稳定检索】2024年第四届人工智能与工业技术应用国际学术会议(AIITA 2024)

2024年第四届人工智能与工业技术应用国际学术会议&#xff08;AIITA 2024&#xff09; 2024 4th International Conference on Artificial Intelligence and Industrial Technology Applications 2024年4月12日-14日 | 中国广州 大会官网&#xff1a;www.aiita.net 二轮截稿…

【项目管理】CMMI-项目监督和控制

项目监督和控制&#xff08;Monitoring and Control, MC&#xff09;的目的是通过周期性地跟踪项目计划的各种性能参数如工作产品的规模、工作量、成本、进度、风险等&#xff0c;不断地了解项目的进展情况&#xff0c;以便当项目实际进展状况显著偏离项目计划时能够及时采取纠…

shapely 笔记 voronoi图

Voronoi 图是一种将平面分割成区域的方法&#xff0c;每个区域包含一个输入点&#xff0c;任何在该区域内的点都比其他输入点更接近该区域的输入点 1 基本使用方法 shapely.ops.voronoi_diagram(geom, envelopeNone, tolerance0.0, edgesFalse) 2 参数说明 geom任何几何类型…

Recorder 实现语音录制并上传到后端(兼容PC和移动端)

Recorder 首页&#xff1a;https://github.com/xiangyuecn/Recorder 一、安装 npm install recorder-core二、代码部分 1. HTML页面 <template><div><el-inputv-model"ttsText"type"textarea"placeholder"请输入内容"><…

Django学习笔记-创建第一个django项目

1.创建一个虚拟环境的python项目 2.点击解释器设置 3.安装django包 4.终端选择Command Prompt 5.创建django项目运行django-admin startproject demo01(自命名) 6.修改连接数据库为mysql 7.修改语言(中国汉语)和时区(亚洲上海)USE_TZ改为False,否则时区不生效 8.修改TEMPLA…

python毕设选题 - 大数据商城人流数据分析与可视化 - python 大数据分析

文章目录 0 前言课题背景分析方法与过程初步分析&#xff1a;总体流程&#xff1a;1.数据探索分析2.数据预处理3.构建模型 总结 最后 0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到…

js设计模式:迭代器模式

作用: 对数据对象进行有序的迭代操作,可以按顺序处理每一个元素 并且可以根据当前步骤的处理结果决定下一个步骤是否操作 示例: class Life {constructor(data) {this.data datathis.child data.childthis.young data.youngthis.middle data.middlethis.old data.old}/…

外贸人大部分都复工了吧

这几天是属于国家规定的节后上班时间&#xff0c;估计大部分人都已经开始复工了。作为粤西地区小伙伴中的一员&#xff0c;表示虽然身在广州&#xff0c;心却还在高州&#xff0c;毕竟年例在这些天才刚刚开始&#xff0c;我们那边每年最热闹的时候就是年例了&#xff01; 由于…

零基础入门金融风控-贷款违约预测Task2 数据分析

Task2 数据分析 此部分为零基础入门金融风控的 Task2 数据分析部分&#xff0c;带你来了解数据&#xff0c;熟悉数据&#xff0c;为后续的特征工程做准备&#xff0c;欢迎大家后续多多交流。 赛题&#xff1a;零基础入门数据挖掘 - 零基础入门金融风控之贷款违约 目的&#…

第二件事 在Java 虚拟机 (JVM)跑一个程序

上篇文章写了 在 WINDOWS上 创建了一个 JVM&#xff0c; 好&#xff01; 现在在这个 Java 虚拟计算机系统上跑一个Java语言编写的小程序&#xff1b; 题目&#xff1a; 用Java语言 编写一个小程序 在Console界面 打印 整数 1-10 (回头了一下源程序&#xff0c;靠&#xff0c;应…

【压缩感知基础】Nyquist采样定理

Nyquist定理&#xff0c;也被称作Nyquist采样定理&#xff0c;是由哈里奈奎斯特在1928年提出的&#xff0c;它是信号处理领域的一个重要基础定理。它描述了连续信号被离散化为数字信号时&#xff0c;采样的要求以避免失真。 数学表示 Nyquist定理的核心内容可以描述如下&…

Reactive到Spring WebFlux的来龙去脉

感谢下述博客作者提供的干货。本文只是做一个整理&#xff0c;归纳&#xff0c;以供自己或者他人学习之用。 一文弄懂 Spring WebFlux 的来龙去脉 - 知乎概述本文将通过对 Reactive 以及相关概念的解释引出 Spring-WebFlux&#xff0c;并通过一些示例向读者解释 基于 Spring-W…