前言

在日常开发中,我们难免会遇到:

  • 改错代码:推送之前才发现某些行根本就不该动
  • 提交错误:commit 信息打错、提交到错误分支
  • 想回到之前版本:测试时发现之前版本是好的,需要回去查看

这就需要用到 Git 的回退操作。Git 提供多种回退方式,比如:checkoutresetrevertreflog 等。下面会从最常见的场景入手,一步步解释 怎么做 + 为什么这样做


1. 概念简单区分

为了后面理解更顺畅,先做最简要的概念区分:

  • 工作区(Working Directory):就是你平时编辑文件所在的那一层文件夹。
  • 暂存区(Staging Area):你用 git add 之后,文件的修改就放到这里,等待下一次提交。
  • 本地仓库(Local Repository):你执行 git commit 后,才真正存到本地仓库里。
  • 远程仓库(Remote Repository)git push 后,修改才会传到远程,比如 GitHub、GitLab 等。

不同的回退命令,操作作用在不同的阶段。


2. 撤销尚未提交的修改(还在工作区)

场景示例

你刚写完一段代码,突然发现完全写错了,还没来得及用 git add。你想丢弃掉这一切。

命令

# 撤销当前工作区所有未提交的更改
git checkout -- .

或者,如果只想丢弃某个文件的更改:

git checkout -- <filename>

详解

  • checkout -- <文件> 会用最近一次提交中的版本覆盖你的工作区文件,达成“把文件回滚到上次提交状态”的效果。
  • 这时候,如果你还没有 git add,那么这个命令就是最简单的丢弃本地改动方式。

3. 撤销已 git add 但未 commit 的修改

场景示例

你已经执行了 git add somefile.py,但没执行 git commit。突然发现有些改动是不想提交的。

命令

  1. 先把文件从暂存区移回工作区:
    git reset HEAD <filename>
    
  2. 再丢弃该文件在工作区的改动(如果还要丢弃的话):
    git checkout -- <filename>
    

详解

  • git reset HEAD <filename>:把 <filename>暂存区撤回到工作区
  • git checkout -- <filename>:丢弃工作区中的改动,回到上一次提交的状态。

如果你只是想取消暂存,但是保留文件的编辑(也许还想再改),那就只执行第一步即可。


4. 撤销最近一次提交:git reset 的用法

当你已经提交了 (commit),但你后悔了,比如提交漏写了某些文件、或者发现了语法错误,想重新来。

4.1 保留改动到工作区:--soft

“我想把最新一次提交退回,但代码还留着(我想再改改,之后重新提交)。”

git reset --soft HEAD~1
  • HEAD~1 表示上一个提交(也可以用 commit ID 的前几位代替)。
  • --soft 会把那次提交的所有改动放回到“暂存区”,让你可以继续进行修改或重新提交。

4.2 完全丢弃改动:--hard

“我想彻底删除最近一次提交里的所有更改,干干净净回到上一个版本。”

git reset --hard HEAD~1
  • 这会永久删除那次提交及其工作区更改,除非你通过 reflog 找回。
  • 请谨慎操作:如果你需要的内容都没了,可能得不到恢复。

示例场景

  1. 你写了一个新功能,git commit -m \"add new feature\"
  2. 结果发现写错功能逻辑,决定先回到不带该功能的旧版本去调试。
    • 如果你还想保留这段代码,可以改良后再提交:
      git reset --soft HEAD~1
      # 现在那次提交的改动还在暂存区,你可以用编辑器继续修改
      git commit -m \"fix new feature\"
      
    • 如果你完全不想要那次提交,干脆删掉:
      git reset --hard HEAD~1
      # 彻底回到之前的版本
      

5. 撤销某一次特定提交:git revert

场景示例

你在历史上第 10 个提交里改了数据库配置,影响到现在的运行。想把那次提交撤销,但又不想影响中间其他 commits。

命令

git revert <具体的commit_id>

执行后,会自动开启一个编辑器让你写“撤销 xx 提交”的说明,然后自动生成一个新的提交,用以反向撤销指定版本的改动。

详解

  • git revert 不会改变原来的提交历史,而是生成一个“负向补丁”把之前提交的内容给抵消掉。
  • 这种做法最安全:不会打乱别人的历史,也不需要强制推送。团队协作中非常常用。

6. 想把本地回退同步到远程:强制推送 git push -f

场景示例

你在本地用 git reset --hard 回退到了一个老版本,然后希望远程仓库也回退。此时,如果直接 git push,Git 会拒绝,因为本地分支历史“比远程版本更旧”。

命令

git push origin <branch_name> --force
  • 这会把远程仓库对应分支的提交历史整体替换成你本地的版本。

风险提示

  • 一旦你强制推送,之前在远程的提交记录将被覆盖。
  • 如果有其他人基于那几个被覆盖的提交做了工作,会引起冲突或混乱。
  • 因此,强制推送前,一定先跟团队沟通

7. 误操作后的救命绳:git reflog

场景示例

你一激动用 git reset --hard HEAD~2 结果发现需要的东西被删了。或者你已经 push -f 把远程也覆盖了……

命令

git reflog

会列出所有操作记录,包括 checkoutcommitresetmergerebase 等。你会看到一串记录,如:

a1b2c3d HEAD@{0}: reset: moving to HEAD~2
f6g7h8i HEAD@{1}: commit: add new feature
...
  • 你可以找到需要的提交 ID,然后用:
    git reset --hard <提交ID>
    
    或者
    git checkout <提交ID>
    
    把那个版本再取出来。

详解

  • reflog 相当于 Git 的本地“操作历史日志”。只要本地没有执行更深度的清理(比如 git gc --prune=now),通常都能在 reflog 找到过往的 commit。
  • 这是你“最后的后悔药”,别轻易乱删本地仓库!

8. 你可能关心的常见问题

  1. 已经 push 到远程的提交,能不能用 reset 撤销?
    • 可以,但要用 push -f 强制推送,会影响其他人。所以一般用 git revert 而不是 reset
  2. git revertgit reset 有啥区别?
    • reset 是改变历史本身,“抹掉”提交;revert 是做一个新的提交来“抵消”之前提交的变化。revert 更安全,协作中更推荐。
  3. 能不能同时撤销多个提交?
    • 可以:git revert a1b2c3d..f6g7h8i (如果中间需要处理冲突,也要人工处理)。不过要对 git revert 比较熟悉才行。
  4. 回退后发现我又需要那段代码,怎么办?
    • 看看 reflog 能不能救。因为 reset --hard 并不是真正销毁,除非被垃圾回收 (git gc) 清理。

总结:回退操作一览表

需求场景操作风险性
工作区未暂存的改动想丢弃git checkout -- <file>
已暂存(但未提交)的改动想丢弃git reset HEAD <file> + git checkout -- <file>
撤销本地最后一次提交,保留改动到工作区git reset --soft HEAD~1相对可控
彻底删除最后一次提交,不保留改动git reset --hard HEAD~1高,无法轻易恢复
撤销历史中某个特定提交(留下回滚记录)git revert <commit_id>
强制把回退操作更新到远程git push -f origin <branch>高,需沟通
查看所有本地操作日志,从中找到想恢复的 commitgit reflog无风险(只读)

结束语

以上就是 Git 回退最常用的几种操作,结合了具体的使用场景和示例流程。作为新手,最重要的是:

  1. 明白回退命令改动的是哪些区(工作区、暂存区、本地仓库、远程仓库)
  2. 回退前先想清楚:自己是否真的要破坏历史?能不能用 git revert?
  3. 一旦强制推送,一定要先沟通
  4. 误操作之后,别忘了 git reflog

希望这篇指南能帮助你在回退操作时更加从容,避免一些“万劫不复”的失误。祝你在开发中“一骑绝尘”、少踩坑、多出成果!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/84280.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/84280.shtml
英文地址,请注明出处:http://en.pswp.cn/web/84280.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redux以及react-redux

1.redux案例完整版 上一篇文章我们是没有action文件&#xff0c;直接在countre组件与store以及reducer直接进行状态的改变以及展示。 下面我们加上action文件&#xff0c;我们就不能直接通过dispatch传&#xff0c;而是通过调用action里面的函数讲我们传入的参数变成action这种…

idea中配置svn及提交提示“未检测到更改”提示

首先要安装TortoiseSVN&#xff0c;选command line client tools&#xff1b; 在idea中&#xff0c;文件->设置->Subversion->如下图 文件->设置->目录映射->如下图 初次导入到svn&#xff0c; 输入服务器上的svn地址&#xff0c;等待成功即可&#xff1b;…

vue 实现dot-dropdown

<template><div class"app-container"><div class"mt30"></div><el-row :gutter"20"><!-- title --><!-- <div class"modt-box">导航管理</div> --><el-col :span"2&q…

使用 mysql2/promise 模块返回以后,使用 await 返回数据总结

SELECT 返回结构 const [rows, fields] await db.query(SELECT * FROM folders);返回&#xff1a; rows: 是一个数组&#xff0c;包含所有查到的记录。fields: 是字段的结构定义&#xff08;列信息&#xff09;&#xff0c;一般不用。 rows 是一个数组&#xff0c;包含所有…

Manus Metagloves pro高精度+无漂移+低延迟 ,重构VR/XR手部交互方式

manus metagloves pro是一款专为动画制作、虚拟现实及游戏开发打造的高精度无线动作捕捉手套。采用先进的Quantum追踪技术&#xff0c;实现毫米级动作捕捉&#xff0c;精准还原手指细节&#xff0c;显著提升创作效率与交互真实感。 MANUS Metagloves Pro解锁动捕 / 机器人 / XR…

Uniapp插件改造指南:如何让vue-plugin支持HarmonyOS5原生能力?

一、分层架构设计 采用通用逻辑与平台实现分离的三层结构&#xff1a; uni-plugin-harmony ├── common # 跨平台通用层 │ ├── interfaces # 能力接口抽象&#xff08;如Scanner.ets&#xff09; │ └── utils # 工具类 ├── harmony …

P1040 [NOIP 2003 提高组] 加分二叉树 题解

题目描述 设一个 n n n 个节点的二叉树 tree \text{tree} tree 的中序遍历为 ( 1 , 2 , 3 , … , n ) (1,2,3,\ldots,n) (1,2,3,…,n)&#xff0c;每个节点都有一个分数&#xff08;均为正整数&#xff09;。任一棵子树 subtree \text{subtree} subtree&#xff08;包含 tr…

【Golang面试题】Data Race 问题怎么检测?

Go Race Detector 深度指南&#xff1a;原理、用法与实战技巧 一、什么是数据竞争&#xff1f; 在并发编程中&#xff0c;数据竞争发生在两个或多个 goroutine 同时访问同一内存位置&#xff0c;且至少有一个是写操作时。这种竞争会导致不可预测的行为和极其难以调试的问题。…

257. 二叉树的所有路径(js)

257. 二叉树的所有路径——DFS 回溯&#xff08;js&#xff09; 题目描述解题思路完整代码时间复杂度分析 题目描述 257. 二叉树的所有路径 解题思路 题意理解 给定一棵二叉树&#xff0c;要求返回所有从根节点到叶子节点的路径&#xff0c;路径以字符串形式表示&#xff0c…

自动化文档生成工具(亲测可运行)

本文介绍了一个用Java编写的自动化文档生成工具&#xff0c;通过读取开发清单文本自动生成格式规范的Word文档。该工具的主要特点包括&#xff1a; 采用Apache POI库处理Word文档&#xff0c;支持多级标题和段落自动生成实现中文数字转换功能&#xff0c;将编号转换为"一、…

湖北理元理律师事务所债务优化模型:法律与生活的平衡之道

在债务重组领域&#xff0c;专业机构需同时解决两个矛盾&#xff1a;法律合规性与债务人可持续生存能力。湖北理元理律师事务所通过“三维干预模型”&#xff0c;在武汉某餐饮连锁企业债务危机中验证了该方案的有效性。 一、法律底层设计&#xff1a;还款方案的合法性审查 以该…

Web3-代币ERC20/ERC721以及合约安全溢出和下溢的研究

Web3-代币ERC20/ERC721以及合约安全溢出和下溢的研究 以太坊上的代币 如果你对以太坊的世界有一些了解&#xff0c;你很可能听人们聊过代币— ERC20代币 一个 代币 在以太坊基本上就是一个遵循一些共同规则的智能合约——即它实现了所有其他代币合约共享的一组标准函数&…

论文笔记 <交通灯><多智能体>MetaLight:基于价值的元强化学习用于交通信号控制

今天看的论文是这篇MetaLight:基于价值的元强化学习用于交通信号控制 里面提到的创新点就是MetaLight框架&#xff1a;他目标是让交通信号控制智能体&#xff08;Agent&#xff09;在新路口&#xff08;即使结构或流量模式不同&#xff09;上能​​快速学习​​&#xff08;Few…

华为OD-2024年E卷-寻找符合要求的最长子串[200分] -- python

问题描述&#xff1a; 给定一个字符串s&#xff0c;找出这样一个子串: 1)该子串中的任意一个字符最多出现2次; 2)该子串不包含指定某个字符; 请你找出满足该条件的最长子串的长度。 输入描述 第一行为要求不包含的指定字符&#xff0c;为单个字符&#xff0c;取值范围[0-9a-zA…

CppCon 2016 学习:What C++ Programmers Need to Know about Header <random>

随机数生成的历史背景 Middle-Square 方法&#xff08;中位平方法&#xff09;&#xff1a; 已知最早的随机算法之一或由修道士 Brother Edvin 在 1245 年发明由 John von Neumann 在 1949 年重新发现缺点明显&#xff0c;但执行速度快 Monte Carlo 方法&#xff1a; 起初是…

Origin:误差棒点线图绘制

1.首先将你的数据复制到表格 2.选中B(y)列数据&#xff0c;依次点击图示选项 3.选中图中红框数据&#xff0c;点击绘制点线图即可 4.结果展示

Spring 源码学习 1:ApplicationContext

Spring 源码学习 1&#xff1a;ApplicationContext Bean 定义和 Bean 实例 AnnotationConfigApplicationContext 首先&#xff0c;创建一个最简单的 Spring Boot 应用。 在入口类中接收SpringApplication.run的返回值&#xff1a; SpringBootApplication public class Dem…

CppCon 2017 学习:Design Patterns for Low-Level Real-Time Rendering

这段内容讲的是离散显卡&#xff08;Discrete GPU&#xff09;中的内存管理模型&#xff0c;重点是CPU和GPU各自独立管理自己的物理内存&#xff0c;以及它们如何通过虚拟内存和DMA引擎实现高效通信。以下是详细的理解和梳理&#xff1a; 1. 基本概念 CPU 和 GPU 是两个独立的…

【单调队列】-----【原理+模版】

单调队列 一、什么是单调队列&#xff1f; 单调队列是一种在滑动窗口或区间查询中维护候选元素单调性的数据结构&#xff0c;通常用于解决“滑动窗口最大值/最小值”等问题。 核心思想是&#xff1a;利用双端队列&#xff08;deque&#xff09;维护当前窗口内或候选范围内元素…

CSS语法中的选择器与属性详解

CSS:层叠样式表&#xff0c;Cascading Style Sheets 层叠样式表 内容和样式分离解耦&#xff0c;便于修改样式。 特殊说明&#xff1a; 最后一条声明可以没有分号&#xff0c;但是为了以后修改方便&#xff0c;一般也加上分号为了使用样式更加容易阅读&#xff0c;可以将每条代…