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 要谨慎使用,以免丢失重要代码。

相关推荐
可乐加.糖6 小时前
项目版本管理和Git分支管理方案
java·git·目标跟踪·gitlab·敏捷流程·源代码管理
wingaso7 小时前
[经验总结]删除gitlab仓库分支报错:错误:无法推送一些引用到“http:”
linux·数据仓库·git
ice___Cpu15 小时前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
范纹杉想快点毕业1 天前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
qq_653644461 天前
如何查看打开的 git bash 窗口是否是管理员权限打开
开发语言·windows·git·bash
tonngw1 天前
【Mac 从 0 到 1 保姆级配置教程 12】- 安装配置万能的编辑器 VSCode 以及常用插件
git·vscode·后端·macos·开源·编辑器·github
橄榄熊1 天前
Git 常用命令详解
git
o(╥﹏╥)2 天前
绑定 SSH key(macos)
开发语言·git·学习·macos
半新半旧2 天前
Git 分支指南
git
qq_464357013 天前
git中忽略文件.gitignore文件的用法
git