git 软重置的使用场景git reset --soft HEAD~1

首先给出命令

git reset --soft HEAD~1

这个命令的作用是 撤销最后一次提交(HEAD~1表示当前提交的前一个提交)

  • --soft 参数:保留修改内容在暂存区中,而不是丢弃它们

具体效果:

  • 撤销提交:取消了提交 30b24cd7cc013a3cacc5d34836306f8d85ec38e1
  • 保留修改:该提交中的所有文件修改都保留在暂存区(staged状态)
  • 回到上一版本:HEAD现在指向 e635419baa28e53162dbde486e74cf8c8977ffb1

这样您就可以对暂存区中的修改进行任何需要的调整,然后重新提交了。

怎么理解这个命令,他的实际场景是什么?

复制代码
root@vm-123:~/001/foundation/multimedia# git log
commit 30b24cd7cc013a3cacc5d34836306f8d85ec38e1 (HEAD -> OhOS_5.0.2_Release_Zhanhong)
Author: lijilei <lijilei@kaihong.com>
Date:   Thu Dec 4 08:45:06 2025 +0000

    <hotfix><30970><解决 galaxy_net_tool的TryPingGet命令因为输入的字符长度过长导致工具崩溃;><source:int; >
    
    Change-Id: Ib4101e034a018fa8173936c8bdeb67a1ffdc124b

commit e635419baa28e53162dbde486e74cf8c8977ffb1 (m/KaihongOS_5.0.1_Release_Zhanhong, kaihong/OhOS_5.0.2_Release_Zhanhong, KaihongOS_5.0.1_Release_Zhanhong)
Author: jenkins <scm@kaihong.com>
Date:   Wed Dec 3 20:07:54 2025 +0800

    <SCM><none><5.0.3推送行业PDU 多媒体相关仓库代码><source:int;none>

commit 656d3c0313cd8e0ec4f62c40ad8bedcd724d252d
Author: jenkins <scm@kaihong.com>
Date:   Wed Dec 3 17:00:10 2025 +0800

    <SCM><none><5.0.3推送行业PDU 多媒体相关仓库代码><source:int;none>

commit 794790a562c0e6d076f120450105590d5b97b622
Author: miaojianan <miaojianan@kaihong.com>
Date:   Wed Dec 3 16:46:05 2025 +0800

    <SCM><none><5.0.3推送行业PDU 多媒体相关仓库代码><source:int;none>

HEAD标识当前节点,本次log显示我本地有一笔提交,因为这个项目是通过gerrit管理的,提交的时候使用的命令是

现在我发现我的这笔提交出错了,需要回退,但是我又想保留提交的内容,因为我只是部分内容需要修改

这时候就执行 git reset --soft HEAD~1

执行完了发生了什么?

查看下发现现在的状态回到了git add 的状态,后面接着执行git commit 和 git push就可以再次提交到远端分支

这种软重置的方法可以修改commit信息,可以回退误提交的文件

当本地提交被gerrit审核合入后,git pull

相关推荐
杰瑞学AI2 小时前
在Git的缩写哈希中踩的坑
git
dragoooon343 小时前
[Linux网络基础——Lesson9.「TCP 全连接队列与 tcpdump 抓包」]
前端·git·github
大、男人4 小时前
分享一个git设备代理的方法
git
悟悟悟!4 小时前
git使用笔记:git日常工作流和命名规范
笔记·git·elasticsearch
漏洞文库-Web安全4 小时前
CTFHub 信息泄露通关笔记9:Git泄露 Index - 指南
笔记·git·安全·web安全·elasticsearch·网络安全·ctf
weixin_307779134 小时前
深度解析 Jenkins Git Client 6.4.0 插件:核心功能、应用场景与最佳实践
运维·git·架构·jenkins
終不似少年遊*4 小时前
【Git使用】Git 团队开发常用命令汇总手册
git·团队开发·开发工具·使用手册·项目提交
郑州光合科技余经理13 小时前
同城系统海外版:一站式多语种O2O系统源码
java·开发语言·git·mysql·uni-app·go·phpstorm
郑州光合科技余经理16 小时前
基于PHP:海外版同城O2O系统多语言源码解决方案
java·开发语言·git·spring cloud·uni-app·php·uniapp