Git Reset 命令详解与实用示例

文章目录

  • [Git Reset 命令详解与实用示例](#Git Reset 命令详解与实用示例)
    • [`git reset` 主要选项](#git reset 主要选项)
    • [`git reset` 示例](#git reset 示例)
      • [1. 撤销最近一次提交(但保留更改)](#1. 撤销最近一次提交(但保留更改))
      • [2. 撤销最近一次提交,并清除暂存区](#2. 撤销最近一次提交,并清除暂存区)
      • [3. 彻底撤销提交,并丢弃所有更改](#3. 彻底撤销提交,并丢弃所有更改)
      • [4. 回退到特定的提交](#4. 回退到特定的提交)
      • [5. 取消暂存的文件](#5. 取消暂存的文件)
    • [`git reset` 与 `git revert` 的区别](#git resetgit revert 的区别)
    • 总结

Git Reset 命令详解与实用示例

git reset 是一个强大的 Git 命令,主要用于撤销提交(commit)、修改暂存区(staging area)或工作区(working directory)。它可以让你回到某个特定的提交,或者只撤销最近的更改,而不影响历史记录。

git reset 主要选项

  1. --soft:只回退提交(commit),保留暂存区和工作区的更改。
  2. --mixed(默认):回退提交,并且清空暂存区(staging area),但保留工作区的更改。
  3. --hard:回退提交,同时清空暂存区和工作区的所有更改。

git reset 示例

1. 撤销最近一次提交(但保留更改)

bash 复制代码
git reset --soft HEAD~1
  • HEAD~1 表示回退到上一个提交。
  • 仅撤销 commit,但文件的修改仍保留在暂存区(staging area)。
  • 适用于:想修改最后一次提交但不想丢失已暂存的内容。

2. 撤销最近一次提交,并清除暂存区

bash 复制代码
git reset --mixed HEAD~1
  • 仅撤销 commit,同时将暂存区的更改退回到工作区(但不删除更改)。
  • 适用于:提交了代码但不想保留这个提交,而是继续修改。

3. 彻底撤销提交,并丢弃所有更改

bash 复制代码
git reset --hard HEAD~1
  • 该命令会将代码回退到上一个提交,并删除所有未提交的更改(无法恢复)。
  • 适用于:不想保留本地的修改,需要完全回到上一个提交的状态。

4. 回退到特定的提交

bash 复制代码
git reset --hard <commit-hash>
  • <commit-hash> 是目标提交的哈希值(git log 可以查看)。
  • 适用于:回到某个特定版本,并清除之后的所有更改。

5. 取消暂存的文件

bash 复制代码
git reset HEAD <file>
  • 取消对 <file> 的暂存,但保留其更改。
  • 适用于:错误地使用 git add 暂存了文件,需要取消暂存但不丢失更改。

git resetgit revert 的区别

  • git reset 会直接修改历史记录,适合本地修改,不适用于已推送的提交。
  • git revert 通过创建新的提交来撤销某个提交,适用于共享仓库。

示例:

bash 复制代码
git revert <commit-hash>
  • 这不会改变提交历史,而是生成一个新的撤销提交,适合多人协作。

总结

命令 作用 影响
git reset --soft HEAD~1 撤销最近一次提交 保留暂存区和工作区的更改
git reset --mixed HEAD~1 撤销最近一次提交,清除暂存区 保留工作区的更改
git reset --hard HEAD~1 撤销最近一次提交,并清除所有更改 丢失所有未提交的更改
git reset HEAD <file> 取消暂存区的文件 保留工作区的更改
git revert <commit-hash> 撤销某次提交,并生成新的提交 不修改提交历史,适合共享仓库

如果你对历史回退有顾虑,建议使用 git revert,而 git reset --hard 要谨慎使用,以免丢失重要代码。

相关推荐
qq_435287927 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
AIMath~14 小时前
Git 子模块(Submodule)目录结构清除实战复盘
git
切糕师学AI15 小时前
Ubuntu 下 Git 完全使用指南
linux·git·ubuntu
一袋米扛几楼9816 小时前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
尘埃落定wf17 小时前
# GitHub CLI:告别繁琐的 Git 命令,让开发更高效
git·github
恋喵大鲤鱼17 小时前
git clone
git·git clone
金牛IT19 小时前
Gogs 轻量级 Git 服务器搭建与使用
运维·服务器·git
Qres8211 天前
Git安装记录
git
wj3055853781 天前
Codex + Git 开发环境配置指南(WSL版)
linux·运维·git
楠枬1 天前
Git 分支管理
git