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

相关推荐
泰勒朗斯8 小时前
如何在新机器上设置github完成内容git push
git·github
小妖66613 小时前
git branch -a 还有一些已经删除了的分支
git
&Sinnt&1 天前
Git 版本控制完全指南:从入门到精通
git·后端
Tiny2141 天前
多人协同开发时Git使用命令
git
WebGirl1 天前
代码Revert后再次Merge会丢失的问题
git
小皮侠2 天前
nginx的使用
java·运维·服务器·前端·git·nginx·github
HalukiSan2 天前
如何提交PR
git·gitlab·github
爱莉希雅&&&2 天前
shell编程之awk命令详解
linux·服务器·git
baiyu332 天前
成为git砖家(12): 看懂git合并分支时冲突提示符
git
wu_aceo2 天前
将本地项目提交到Gitee
git·gitee·提交·本地提交·上传git