当前位置: 首页 > news >正文

Git中revert和reset区别?

git revertgit reset 都用于撤销 Git 中的提交,但它们的作用和使用场景不同:

  1. git revert:

    • 作用:创建一个新的提交,撤销指定的提交内容。
    • 使用场景:用于“回滚”已推送到远程仓库的提交。这种方法不会改变提交历史,只是添加一个新的提交,反向操作指定的提交内容。
    • 示例:如果你想撤销最后一次提交,但保留历史记录,可以用:
      git revert HEAD
      
      这将创建一个新的提交,该提交撤销 HEAD 指向的那个提交。
  2. git reset:

    • 作用:重置当前分支的指针到指定的提交,可以选择是否修改工作区和暂存区的内容。
    • 使用场景:用于本地回退到某个提交,常用于撤销未推送到远程仓库的提交。git reset 会改变历史记录,可能会导致丢失数据,尤其是如果使用了 --hard 选项时。
    • 示例
      • git reset --soft <commit>:只移动分支指针,不更改工作区和暂存区。适用于想要撤销提交,但保留修改的场景。
      • git reset --mixed <commit>:移动分支指针并重置暂存区,不更改工作区。适用于希望撤销提交并重新暂存的场景。
      • git reset --hard <commit>:彻底重置,包括工作区和暂存区的更改。适用于完全撤销某个提交的场景,但要小心,因为数据会丢失。

总结

  • git revert 适用于已推送的提交,它会创建一个新提交来撤销某个提交的效果,适合多人协作。
  • git reset 适用于本地操作,它可以改变提交历史,并且有多种方式控制是否影响工作区,适合在推送之前进行修改。

你通常会选择 revert 来保持历史不变,而选择 reset 来彻底修改提交历史(仅限本地操作)。

http://www.dtcms.com/a/29388.html

相关文章:

  • 如何将MySQL数据库迁移至阿里云
  • Pipeline 获取 Jenkins参数
  • 二叉树(数据结构)
  • 第5章:在LangChain中如何使用AI Services
  • 45.日常算法
  • 【算法通关村 Day6】二叉树层次遍历
  • Leetcode 76 Minimum Window Substring
  • 哈希表(概念)c++
  • 数据结构——模拟栈例题B3619
  • ShardingSphere 数据库中间件【详解大数据量下分库分表,读写分离,主从同步,以及ShardingSphere-JDBC使用,附有示例+代码】
  • 简单工厂模式 (Simple Factory Pattern) 在Spring Boot 中的应用
  • 机器学习实战(10):深度学习初探——卷积神经网络(CNN)
  • OpenGL(2)基于Qt做OpenGL开发
  • 深⼊理解指针(1)
  • 电脑想安装 Windows 11 需要开启 TPM 2.0 怎么办?
  • 从零开始学习PX4源码9(部署px4源码到gitee)
  • 低代码表单引擎刷新机制
  • Redis 存在线程安全问题吗?为什么?
  • 排查JVM的一些命令
  • langchain系列 - FewShotPromptTemplate 少量示例
  • Linux 和 Windows 区别
  • C++的封装(十五):第四种访问控制
  • STL 在线转 3MF,开启 3D 模型转换新体验
  • krpano学习笔记,端口修改,krpano二次开发文档,krpano三维div信息展示,krpano热点显示文字
  • Java 中的方法参数传递与值传递
  • 面试题之介绍下call,apply,bind相同点和不同点
  • linux 搭建nfs服务(共享文件夹)
  • 探索HarmonyOS的UI开发新境界:从基础到进阶的深度解析
  • leetcode刷题第十三天——二叉树Ⅲ
  • arm环境下,wpa_supplicant交叉编译+wifi sta连接详解