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

Git Reset命令介绍(用于移动HEAD,并选择是否同步更新暂存区工作区)三种模式:--soft、--mixed(默认)、--hard;修改最近提交、合并多个提交、取消git add、回退版本回退

注意区分git reset和git reset HEAD~1功能完全不同git reset只用于取消文件暂存命令移动HEAD重置暂存区保留工作目录更改主要用途git reset❌ 不移动✅ 重置到HEAD✅ 保留取消文件暂存git reset HEAD~1✅ 移动到前一个提交✅ 重置✅ 保留撤销最后一次提交保留修改git reset --mixed HEAD~1✅ 移动到前一个提交✅ 重置✅ 保留同上与上者等价文章目录Git Reset 命令详解撤销提交、回退代码与重置状态一、理解 Git 三大区域核心前提1. Working Directory工作区2. Staging Area暂存区 / Index3. Repository本地仓库二、git reset 的本质三、reset 的三种模式最核心四、git reset --soft作用示例等价理解常见用途1. 修改最近一次 commit2. 合并多个 commit五、git reset --mixed默认作用示例状态变化最常见用途1. 取消 git add2. 拆分一次提交六、git reset --hard作用示例七、hard reset 的危险性非常重要使用前建议八、reset 常见写法1. 回退一个 commit2. 回退两个 commit3. 回退到指定 commit4. 仅取消暂存5. 重置所有暂存九、HEAD~1 是什么意思含义十、git reset 的典型场景场景 1commit message 写错场景 2提交了不该提交的文件将指定文件从暂存区Staging Area中移除但保留工作目录中的修改内容场景 3commit 太大想拆分场景 4彻底放弃本地修改场景 5本地回退到远程版本十一、git reset 与 git revert 的区别git resetgit revert对比十二、已经 push 后还能 reset 吗force强制推送注意如果已经push了再用reset直接用push不加参数是百分之百拒绝的更安全方式十三、reset 后如何恢复reflog示例十四、reset 的思维模型非常重要十五、实际开发建议推荐原则日常取消 add修改 commit已 push 的 commit慎用 hard十六、总结Git Reset 命令详解撤销提交、回退代码与重置状态在 Git 的日常使用中git reset是一个非常强大、也非常容易误用的命令。很多开发者第一次接触它时都会被它的行为搞混为什么有时候只是取消暂存为什么有时候会回退 commit为什么有时候代码直接没了--soft、--mixed、--hard到底有什么区别这篇文章会系统讲清楚git reset的本质三种 reset 模式reset 对 Git 三大区域的影响常见使用场景与git revert的区别如何避免误操作一、理解 Git 三大区域核心前提学习git reset前必须先理解 Git 的三个区域。1. Working Directory工作区你实际编辑代码的目录。例如vimapp.py修改的内容先存在工作区。2. Staging Area暂存区 / Index通过gitadd加入的内容。它表示“下一次 commit 我要提交这些内容”3. Repository本地仓库通过gitcommit真正保存的历史记录。二、git reset 的本质一句话理解git reset用于“移动 HEAD”并选择是否同步更新暂存区和工作区。也就是说gitreset本质上是在HEAD - 指向新的 commit然后根据参数决定是否修改暂存区是否修改工作区三、reset 的三种模式最核心Git reset 最重要的三个模式模式HEAD暂存区工作区--soft✔❌❌--mixed默认✔✔❌--hard✔✔✔这是整个 reset 的核心。下面逐个解释。四、git reset --soft作用只移动 HEAD。不会修改暂存区工作区示例当前A - B - C (HEAD)执行gitreset--softHEAD~1结果A - B (HEAD)commit C 被“取消”。但是C 的代码还在并且仍然在暂存区等价理解相当于“撤销 commit但保留提交内容”常见用途1. 修改最近一次 commit例如提交信息不小心写错了gitcommit-mwrong message想改 commit messagegitreset--softHEAD~1gitcommit-mcorrect message# 因为没有影响暂存区和工作去可以直接改为正确提交信息再提交2. 合并多个 commit例如A - B - C - D想把C D合并gitreset--softHEAD~2gitcommit-mcombined changes五、git reset --mixed默认这是默认模式。即gitreset HEAD~1等价于gitreset--mixedHEAD~1作用移动 HEAD重置暂存区保留工作区示例执行gitreset--mixedHEAD~1结果commit 被取消文件修改还在但不再处于 staged 状态状态变化之前已 commit之后modified需要重新gitaddgitcommit最常见用途1. 取消 git add例如gitadd.误加文件。取消暂存gitreset注git reset相当于git reset HEAD只重置暂存区index到HEAD状态不会移动HEAD指针。主要用于取消文件的暂存状态unstage files比如把已经git add的文件移出暂存区不会回退任何提交。或者gitreset file.txt2. 拆分一次提交比如你一次提交了很多文件gitcommit想拆成多个 commitgitreset HEAD~1然后重新gitaddfileAgitcommitgitaddfileBgitcommit六、git reset --hard这是最危险的模式。作用同时重置HEAD暂存区工作区示例执行gitreset--hardHEAD~1结果commit 消失staged 消失工作区修改也消失相当于“彻底回到旧版本”七、hard reset 的危险性非常重要gitreset--hard可能导致未提交代码永久丢失尤其gitreset--hardorigin/main会直接覆盖本地修改。使用前建议先查看状态gitstatus或者先备份gitstash八、reset 常见写法1. 回退一个 commitgitreset HEAD~12. 回退两个 commitgitreset HEAD~23. 回退到指定 commitgitreset a1b2c3d4. 仅取消暂存gitreset file.txt5. 重置所有暂存gitreset九、HEAD~1 是什么意思例如A - B - C - D (HEAD)含义写法含义HEAD当前 commitHEAD~1上一个 commitHEAD~2上上个 commit十、git reset 的典型场景场景 1commit message 写错gitreset--softHEAD~1gitcommit-mnew message场景 2提交了不该提交的文件将指定文件从暂存区Staging Area中移除但保留工作目录中的修改内容gitreset HEAD file.txt等价于gitreset file.txt场景 3commit 太大想拆分gitreset HEAD~1重新 add。场景 4彻底放弃本地修改gitreset--hard场景 5本地回退到远程版本gitfetch origingitreset--hardorigin/main十一、git reset 与 git revert 的区别这是高频面试题。git reset本质修改历史特点commit 消失会改变历史指改变提交历史以及“可能”改变工作区代码如果用hard模式git reset --hard HEAD~1的话不适合已经 push 的 commitgit revert本质新建一个“反向 commit”例如A - B - Crevert C 后A - B - C - DD 是“撤销 C”的 commit。对比对比项resetrevert是否改历史✔❌是否安全较危险更安全是否适合已 push❌✔是否删除 commit✔❌十二、已经 push 后还能 reset 吗可以。但危险。force强制推送gitreset--hardHEAD~1gitpush--force会改写远程历史影响团队成员注意如果已经push了再用reset直接用push不加参数是百分之百拒绝的更安全方式优先gitrevert十三、reset 后如何恢复reflog很多人不知道Git 很少真正删除 commit。可以通过gitreflog查看历史 HEAD。示例gitreflog输出a1b2c3 HEAD{0}: reset: moving to HEAD~1 d4e5f6 HEAD{1}: commit: add feature操作reflog 索引时间顺序commit: add featureHEAD{1}前reset: moving...HEAD{0}后数字越大时间越早恢复gitreset--hardd4e5f6十四、reset 的思维模型非常重要记住一句话reset 移动 HEAD然后模式是否同步暂存区是否同步工作区soft否否mixed是否hard是是十五、实际开发建议推荐原则日常取消 add用gitreset修改 commit用gitreset--soft已 push 的 commit优先gitrevert慎用 hard尤其gitreset--hard执行前一定确认。十六、总结git reset是 Git 中最核心、也最容易误操作的命令之一。它真正的本质是移动 HEAD并决定是否同步暂存区和工作区。记住这张表即可理解 90% 的 reset模式HEAD暂存区工作区soft✔❌❌mixed✔✔❌hard✔✔✔开发中最常见的用途撤销 commit取消暂存拆分 commit回退版本放弃修改但同时git reset --hard也可能让代码永久丢失。所以reset 前先git status重要修改先git stash已 push 历史优先git revert这样才能安全、高效地使用 Git。

相关文章:

Git Reset命令介绍(用于移动HEAD,并选择是否同步更新暂存区工作区)三种模式:--soft、--mixed(默认)、--hard;修改最近提交、合并多个提交、取消git add、回退版本回退

注意区分:git reset和git reset HEAD~1(功能完全不同,git reset只用于取消文件暂存) 命令移动HEAD重置暂存区保留工作目录更改主要用途git reset❌ 不移动✅ 重置到HEAD✅ 保留取消文件暂存git reset HEAD~1✅ 移动到前一个提交✅…...

Git Merge命令介绍(把指定分支的提交历史合并到当前分支)经典合并、Fast-Forward快进合并FF Merge、三方合并、merge commit、squash merge、合并冲突

文章目录 Git Merge 完全指南:理解 Git 分支合并机制一、什么是 git merge?merge 是“合并到当前分支” 二、merge 的核心思想三、最经典的 merge 流程四、Fast-Forward Merge(快进合并)场景 五、什么是 Three-Way Merge&#xff…...

Git Restore命令介绍(撤销工作区修改、恢复多个文件、取消暂存:--staged、同时恢复暂存区和工作区:--worktree、-SW、从指定commit恢复文件--source)

文章目录Git Restore 命令详解:安全恢复文件内容的新方式一、git restore 是什么?二、Git 中三个重要区域三、git restore 最常见用途1. 撤销工作区修改四、恢复多个文件五、取消暂存(Unstage)六、同时恢复工作区 暂存区七、从指…...

为什么头部金融机构已秘密部署AISMM-LLM扩展模块?SITS圆桌首曝4项未公开技术接口与适配成本测算

更多请点击: https://intelliparadigm.com 第一章:SITS2026圆桌:AISMM模型的未来发展 在SITS2026国际智能系统技术峰会圆桌讨论中,AISMM(Adaptive Intelligent Semantic Memory Model)被公认为下一代语义建…...

在安卓手机搭建AI智能体服务器:OpenClaw轻量化部署指南

1. 项目概述:在旧手机上搭建一个AI智能体服务器 如果你手头有一台闲置的安卓手机,除了让它吃灰或者换脸盆,现在有了一个更有趣的玩法:把它变成一个24小时在线的AI智能体服务器。我说的不是那种简单的聊天机器人,而是一…...

本地AI对话搜索引擎aii:构建私有知识库与AI助手记忆体

1. 项目概述:打造你的本地AI对话记忆库如果你和我一样,每天都要和Claude Code、Cursor、Codex这些AI编程助手打交道,那么你一定遇到过这个场景:上周明明和AI助手一起解决了一个棘手的Webhook重试问题,但今天想回顾一下…...

java学习笔记(1)

UML类图一、UML类图核心关系详解 UML类图是面向对象设计的“语言”,通过不同的箭头符号,清晰表达类与类之间的交互逻辑,是理解设计原则的基础。 关联关系 类与类之间存在长期的、结构性的联系,比如“用户和订单”,一个…...

Argo CD Helmfile插件:实现多环境Kubernetes应用声明式部署

1. 项目概述:为什么我们需要 Argo CD Helmfile 插件?在 Kubernetes 生态中,Argo CD 和 Helm 的组合已经成为了 GitOps 实践的黄金标准。Argo CD 负责将 Git 仓库中的声明式配置同步到集群,而 Helm 则作为强大的包管理器&#xff0…...

技能进化系统:用数据可视化与网状图谱管理个人知识成长

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫“skill-evolution”。光看这个名字,你可能会联想到技能树、能力进化或者某种学习系统。没错,这个项目本质上就是一个个人技能管理与进化追踪系统。它不是那种简单的待办清单&a…...

GodotFirebase插件实战:为游戏快速集成云端用户认证与实时数据库

1. 项目概述与核心价值 如果你正在用Godot引擎开发游戏,并且希望为你的作品添加一些现代化的后端服务——比如让玩家可以注册登录、保存游戏进度到云端、或者上传下载游戏截图——那么你大概率绕不开Google Firebase。Firebase提供了一整套后端即服务(B…...

【408考研·OS】核心考点:中断分类、线程模型 (KLT/ULT) 与调度算法方法论总结

0. 前言 在操作系统(OS)的复习中,中断处理机制、线程的实现方式以及调度算法的性能分析是三大基础命题点。本文基于今日学习笔记,结合考研真题考点,对这些知识进行深度还原与逻辑梳理。一、 中断与异常的分类与底层支持…...

Bonsai Memory:为AI智能体构建分层记忆索引,实现Token消耗降低81%

1. 项目概述:为AI智能体“修剪”记忆,实现极致Token优化如果你正在使用基于大型语言模型(LLM)的AI智能体,比如OpenClaw或其他任何需要持久化记忆的框架,那么你一定对“上下文窗口”和“Token消耗”这两个词…...

VRM Blender插件:解锁虚拟角色创作的专业解决方案

VRM Blender插件:解锁虚拟角色创作的专业解决方案 【免费下载链接】VRM-Addon-for-Blender VRM Importer, Exporter and Utilities for Blender 2.93 to 5.1 项目地址: https://gitcode.com/gh_mirrors/vr/VRM-Addon-for-Blender 在虚拟角色创作领域&#xf…...

20260507笔记

20260507笔记:vue: vue-router、vue的依赖package.json、组件下载更新机制、export与import、同步组件与异步组件。java: postgreSql的group by、DATE_TRUNC、case when ... then... end、 vue1、vue-router2、vue项目的package.json与package-lock.json3、vue-router是做什么的…...

告别Keil!用Vscode+EIDE无缝接手你的STM32CubeMX项目(保姆级配置流程)

从Keil到Vscode:打造高效STM32开发环境的完整指南 作为一名长期使用Keil进行STM32开发的工程师,我深知传统IDE在现代化开发流程中的局限性。臃肿的界面、缓慢的响应速度以及有限的扩展性,都让我们开始寻找更高效的替代方案。Vscode凭借其轻量…...

终极指南:SketchUp STL插件让你的3D模型轻松实现3D打印

终极指南:SketchUp STL插件让你的3D模型轻松实现3D打印 【免费下载链接】sketchup-stl A SketchUp Ruby Extension that adds STL (STereoLithography) file format import and export. 项目地址: https://gitcode.com/gh_mirrors/sk/sketchup-stl 你是否曾为…...

Taro编译h5端口点击返回Taro.navigateBack({delta: 1,})刷新当前页面问题

笔者在使用Taro开发h5端和小程序的时候发现,在小程序中,正常调用的顶部导航栏组件,代码如下:const backHandle () > {console.log("backHandle");Taro.navigateBack({delta: 1,});};小程序端能正常返回到上级页面&a…...

别再买群晖了!用闲置旧电脑+Docker,30分钟自建NextCloud私有云盘(保姆级教程)

旧电脑秒变私有云:零成本搭建NextCloud全栈指南 看着角落里积灰的旧笔记本,我突然意识到它可能比群晖NAS更强大。去年帮朋友用一台2015年的MacBook Air搭建私有云,至今稳定运行着团队15人的文件协作系统——而这台"报废设备"的市场…...

ChatClaw本地智能信息处理框架:从文档解析到知识库构建全解析

1. 项目概述与核心价值最近在折腾本地大模型应用的时候,发现了一个挺有意思的开源项目,叫ChatClaw。这名字起得挺形象,“Chat”聊天,“Claw”爪子,合起来就是“聊天爪”,听起来就像个能帮你从各种地方抓取信…...

大语言模型应用安全防护:OpenClaw-Guardian框架实战指南

1. 项目概述:从“守护者”到智能安全基座最近在AI安全领域,一个名为“OpenClaw-Guardian”的项目引起了我的注意。这个名字本身就很有意思——“OpenClaw”直译是“开放的爪子”,听起来有点攻击性,而“Guardian”则是“守护者”&a…...

从开源项目到商业落地:一个软PLC的‘前世今生’与技术启示

从开源项目到商业落地:一个软PLC的‘前世今生’与技术启示 在工业自动化领域,软PLC技术正经历着从实验室概念到成熟商业产品的蜕变。十年前,一个名为SPLC的开源项目悄然诞生,它用简陋的梯形图编辑器和基础运行时环境,展…...

基于MCP协议构建企业级AI协作引擎:连接Claude与Gemini的33个生产力工具

1. 项目概述:一个连接Claude与Gemini的AI协作引擎如果你和我一样,每天都在Claude Code或Claude Desktop里写代码、分析文档,那你肯定也遇到过这样的时刻:面对一个复杂问题,你希望听听不同AI模型的意见,或者…...

GaussDB索引实战:从‘商品销售表’案例看5种索引的正确用法与性能对比

GaussDB索引实战:从‘商品销售表’案例看5种索引的正确用法与性能对比 电商平台的数据库查询性能直接影响用户体验和运营效率。想象一个典型场景:促销活动期间,后台系统需要同时处理商品详情页的频繁访问、订单状态的实时查询、多条件筛选的热…...

倒计时90天!SITS2026新规强制要求AISMM评估质量追溯机制,3类组织正紧急补签质量承诺书

更多请点击: https://intelliparadigm.com 第一章:SITS2026专家:AISMM评估质量保障 AISMM(AI Software Maturity Model)是SITS2026国际标准中用于衡量AI系统工程化成熟度的核心框架,其评估质量直接决定组织…...

【国家级信创项目AISMM通关实录】:SITS2026案例深度还原——6个月达标、0项重大不符合项、100%证据一次过审

更多请点击: https://intelliparadigm.com 第一章:SITS2026案例:AISMM评估成功案例 在2026年国际软件测试峰会(SITS2026)上,某国家级金融基础设施平台完成了基于AISMM(AI-Augmented Software M…...

从“让 AI 写代码”到“让 AI 可靠交付”:工程师真正该学什么

开头 这半年,软件开发圈有三个词突然变得很热: Vibe Coding、Agentic Engineering、Harness Engineering。 很多人把它们混在一起讲,好像都是“让 AI 写代码”。 但这三个词背后,其实代表了 AI 软件开发的三个阶段。 第一个阶段&a…...

MVCC与锁联手:彻底搞懂MySQL如何解决幻读

​📌关键词:​MySQL​​、InnoDB、MVCC、Next-Key Lock、幻读​、间隙锁、并发控制、数据库原理 大家好呀!我是数据库小学妹👋 我们之前学了两个重要的并发控制技术:MVCC(多版本并发控制)让读…...

警惕!POS系统4大安全风险别踩雷

随着数字化转型深入,零售企业的网络安全已成为经营的“生命线”——越来越多客户信息、交易数据在云端存储流转,而作为门店核心的收银POS系统,恰恰是黑客攻击的薄弱环节。如何守住门店数据安全底线?保持安全认知、主动前置防护&am…...

AgentBench:多环境基准测试实战,全面评估LLM智能体能力

1. 项目概述:AgentBench,一个重新定义LLM智能体能力的基准测试 如果你最近在关注大语言模型(LLM)如何从“聊天机器人”进化为能执行复杂任务的“智能体”,那么你一定听说过各种炫酷的演示:让AI帮你订机票、…...

Konteks-Skill框架:快速构建与部署标准化AI功能模块的实践指南

1. 项目概述与核心价值最近在折腾一些个人项目,想把一些想法快速落地成可交互的Demo,或者给现有的应用加点“智能”的料。相信很多开发者都有过类似的经历:手头有个不错的模型,或者想调用某个API,但一想到要从前端到后…...