git提交到本地仓库了,怎么撤回

如果你想要撤回已经提交到本地仓库的更改,可以使用以下一些Git命令:

  1. **撤回最后一次提交** (不保留更改):
  • `git reset --hard HEAD~1`:这会撤销最后一次提交,并且所有的更改都会丢失。
  1. **撤回最后一次提交** (保留更改到暂存区):
  • `git reset --soft HEAD~1`:这会撤销最后一次提交,但是更改会保留在暂存区,你可以重新提交。
  1. **撤回最后一次提交** (保留更改到工作目录):
  • `git reset --mixed HEAD~1`:这是默认选项,撤销最后一次提交,更改会保留在工作目录中。
  1. **修改最后一次提交** (例如,添加遗漏的文件或修正提交信息):
  • `git add <遗漏的文件或更改>`:将需要重新提交的文件添加到暂存区。

  • `git commit --amend`:修改最后一次提交的信息或包括新的更改。

  1. **撤回特定文件的更改**:
  • `git checkout -- <file>`:放弃对特定文件的更改。
  1. **撤回所有未提交的更改**:
  • `git reset --hard`:放弃所有未暂存和已暂存的更改。

  • `git clean -fd`:清除所有未跟踪的文件和目录。

  1. **解决冲突后撤回**:
  • 如果在合并或拉取时出现冲突,解决了冲突后,使用`git add`将解决后的文件添加到暂存区,然后`git commit`完成提交。
  1. **使用暂存区(stash)功能**:
  • `git stash`:暂存当前工作进度,包括未提交的更改。

  • `git stash pop`:恢复之前暂存的工作进度。

  1. **回滚到特定提交** (不保留之后的提交):
  • `git reset --hard <commit>`:将HEAD、索引区和工作目录都回滚到指定的提交。

请注意,使用`--hard`选项会丢失所有更改,因此在使用之前请确保这是你想要的操作,或者你已经备份了你的工作。如果你想要撤回已经推送到远程仓库的提交,那么情况会更复杂一些,可能需要使用`git push`的强制推送选项,但这会影响其他协作者的仓库状态。


注意:

撤回最后一次提交 (保留更改到暂存区)撤回到git add .这个命令运行后,撤回最后一次提交 (保留更改到工作目录)这个是撤回到没有执行git add .前

也就是:

  • `git reset --soft HEAD~1`:这个命令会撤回最后一次提交,但保留更改在暂存区(staged)。这意味着所有在最后一次提交中所做的更改仍然被标记为将要提交的(即它们在暂存区)。这个命令不会改变工作目录(working directory),即工作目录中的文件不会被撤销更改。

  • `git reset --mixed HEAD~1`(或简单地 `git reset HEAD~1`,因为这是默认行为):这个命令也会撤回最后一次提交,但更改会被保留在工作目录中。这意味着更改不再标记为将要提交的,它们回到了工作目录,就像你从未运行过 `git add` 一样。

简单来说:

  • `--soft`:撤销提交,但更改保留在暂存区,你可以重新提交。

  • `--mixed`(默认):撤销提交,更改保留在工作目录,需要重新 `git add` 到暂存区。

  • `--hard`:撤销提交,所有更改都会丢失。(注意一般不用这个!!!)

如果你想要撤回到执行 `git add .` 命令之后,但还没有执行 `git commit` 的状态,你可以使用 `git reset --mixed HEAD~1`。这样,你将撤销最后一次提交,并且所有更改会出现在工作目录中,你需要重新 `git add` 这些更改,然后再次提交。

相关推荐
hh随便起个名2 小时前
适合小白的git的基础使用方法
git
我会一直在的3 小时前
Devps持续集成
git·ci/cd
CoderJia程序员甲4 小时前
GitHub 热榜项目 - 日榜(2026-02-08)
git·ai·开源·llm·github
Serene_Dream5 小时前
git 常用命令
git
jiayong235 小时前
Detached HEAD 状态详解
git
李少兄14 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
先跑起来再说20 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
承渊政道1 天前
Linux系统学习【Linux系统的进度条实现、版本控制器git和调试器gdb介绍】
linux·开发语言·笔记·git·学习·gitee
Doro再努力1 天前
【Linux操作系统12】Git版本控制与GDB调试:从入门到实践
linux·运维·服务器·git·vim
摇滚侠1 天前
MAC IDEA GIT 提交区显示了几个不存在的目录
git·idea