idea的git reset current branch to here操作详解

分为四个选项

  1. Soft:

    • 这个选项执行 git reset --soft 命令。
    • 它会重置当前分支到指定的提交,但不改变工作目录或暂存区(Staging Area)。
    • 你的所有更改会被保留并标记为待提交(即,更改会移动到暂存区)。
      场景: 当你想要撤销一些提交,但仍希望保留这些更改以进行进一步的修改和重新提交时。
      例子: 你可能已经进行了几次提交,但意识到这些提交应该合并为一个更大的特性提交。
  2. Mixed:

    • 对应于 git reset --mixed 命令(这也是 Git 默认的重置模式)。
    • 它将当前分支移动到指定的提交,并更新暂存区以匹配该提交,但不会更改工作目录。
    • 更改会保留在工作目录中,但不会自动暂存。
      暂存区和提交都会被重置,但是本地代码不会重置
      场景: 当你想要撤销提交并重新审视更改,可能要做一些修改,然后再次暂存和提交。
      例子: 你可能完成了一些工作,但不满意提交的组织方式,或者想要拆分提交。
  3. Hard:

    • 执行 git reset --hard 命令。
    • 这个选项不仅重置分支到指定提交,还会更新暂存区和工作目录,使其与该提交完全一致。
    • 任何自上次提交以来的更改(无论是否已暂存)都将丢失。这是一个不可逆的操作,应该谨慎使用。
      场景: 当你想要彻底放弃最近的更改,并将代码库恢复到特定提交的状态时。
      例子: 这在你实验性地添加了一些代码或更改,然后决定这些更改不再需要时非常有用。
      (这个我用的比较多,把你的本地代码也重置到那个提交的状态)
  4. Keep:

    • 相当于 git reset --keep 命令。
    • 它重置分支到指定的提交,但保留本地更改,只要它们与重置的目标提交不冲突。
    • 如果你有未提交的更改与重置目标有冲突,操作会被拒绝。
      在错误的分支上进行了工作,需要切换到正确的分支,但不想失去已经进行的工作。
相关推荐
编啊编程啊程21 小时前
【004】生菜阅读平台
java·spring boot·spring cloud·dubbo·nio
Craaaayon21 小时前
【数据结构】二叉树-图解广度优先搜索
java·数据结构·后端·算法·宽度优先
岁岁岁平安21 小时前
Java+SpringBoot+Dubbo+Nacos快速入门
java·spring boot·nacos·rpc·dubbo
@卞21 小时前
版本控制器 git(5)--- git 标签管理
git
学习编程的Kitty1 天前
算法——位运算
java·前端·算法
用户904706683571 天前
如何使用 Spring MVC 实现 RESTful API 接口
java·后端
刘某某.1 天前
数组和小于等于k的最长子数组长度b
java·数据结构·算法
程序员飞哥1 天前
真正使用的超时关单策略是什么?
java·后端·面试
用户904706683571 天前
SpringBoot 多环境配置与启动 banner 修改
java·后端
小old弟1 天前
后端三层架构
java·后端