Git 中的撤销工作区、暂存区和已提交的更改

在使用Git时,了解如何在不同阶段撤销更改至关重要,无论是在工作目录、暂存区,还是在将更改提交到本地仓库之后。本指南将带你了解基本的Git命令,以有效地管理和还原更改,确保你的版本控制过程顺利且无误。

在工作目录中修改文件但尚未添加到暂存区

当你在工作目录中对文件进行了更改但尚未将其添加到暂存区时,如果需要,你可以轻松丢弃这些更改。

  • 丢弃特定文件的更改git checkout [文件名]。使用此命令可将特定文件还原到其上次提交的状态,撤销你所做的任何修改。

  • 丢弃所有文件的更改git checkout.。如果你想丢弃工作目录中所有文件的更改,此命令会将它们重置为上次提交的状态。

  • 查看所做的特定更改git diff [文件名]。在丢弃更改之前,你可能想看看自己修改了什么。此命令将显示对文件所做的特定更改。

撤销已添加到暂存区的文件

如果你已将文件添加到暂存区(git add)但尚未提交,你仍然可以撤销此操作。

  • 撤销已添加到暂存区的文件git reset HEAD [文件名]。此命令将文件从暂存区移除,但更改仍保留在工作目录中。

  • 撤销暂存区中的所有文件git reset HEAD.。如果你想从暂存区移除所有文件,使用此命令。更改将保留在工作目录中。

撤销后,暂存区中的内容将被移除,但工作目录中的修改将被保留,允许你进行进一步的更改或修正。

撤销已提交到本地仓库的更改

有时,你可能需要撤销已提交到本地仓库但尚未推送到远程仓库的更改。

  • 撤销提交但保留暂存区和工作目录中的更改git reset --soft [提交ID]。此命令撤销提交,但更改仍保留在暂存区和工作目录中,允许你修改提交或进行进一步的修改。

  • 撤销提交并取消暂存更改,但保留工作目录中的更改git reset --mixed [提交ID]。此选项撤销提交并取消暂存更改,但你的修改仍存在于工作目录中。

  • 撤销提交并丢弃所有更改git reset --hard [提交ID]。谨慎使用此命令。它将撤销提交、取消暂存更改并丢弃工作目录中的所有修改。

理解这些Git命令使你能够有效地管理代码更改,帮助你自信地应对开发的各个阶段。无论你是丢弃不需要的修改、取消暂存文件还是回滚提交,这些工具对于维护对代码库的控制都是必不可少的。

相关推荐
Edwardwu3 分钟前
写了个y-mxgraph:给 draw.io 接上了 Yjs,顺便解决了部署在 iframe 里的一堆问题
前端·typescript
其实防守也摸鱼7 分钟前
软件安全与漏洞--软件安全编码
java·前端·网络·安全·网络安全·web·工具
发现一只大呆瓜1 小时前
Vite 开发预构建机制详解,搞懂 esbuild 与 Rollup 分工差异
前端·面试·vite
洋仔1 小时前
Git 底层原理系列 · 第8讲 — HEAD 与 detached HEAD
git·开源
洋仔1 小时前
Git 底层原理系列 · 第4讲 — `git add` 与 `git commit` 底层做了什么
git·开源
计算机魔术师1 小时前
【AI面试八股文 Vol.3.4:训练微调部署选型】从预训练到量化部署:LLM 工程落地如何做模型选择
人工智能·后端·面试·架构·moe·vol.3.3·vol.3.4
明月_清风1 小时前
从零到一构建生产级 AI Agent:架构拆解 × Python 高并发实战 × 技术选型方法论
后端·agent
九九落2 小时前
前端获取经纬度完全指南:从Geolocation API到地图集成
前端·获取经纬度
来恩10032 小时前
jQuery选择器
前端·javascript·jquery
前端繁华如梦2 小时前
树上挂苹果还是挂玻璃球?Three.js 程序化果实的完整实现指南
前端·javascript