当前位置: 首页 > 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 来彻底修改提交历史(仅限本地操作)。

相关文章:

  • 如何将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 少量示例
  • 用易语言做攻击网站软件下载/卡点视频免费制作软件
  • 哪里可以接做ppt的网站/免费seo在线工具
  • 校园二手交易网站开发背景/聊城疫情最新消息
  • 有可以花钱让人做问券的网站吗/百度指数的数据来源
  • 想自己建一个公司网站怎么做/搜索关键词排行榜
  • 安徽建设工程信息网技术服务电话/九江seo优化