撤回仓库的提交

结论先行

  • 未推送提交 :可以使用 git reset --soft HEAD~1git reset --hard HEAD~1 来撤回提交,选择保留或丢弃修改。
  • 已推送提交 :可以使用 git reset --soft HEAD~1 后,通过 git push --force 强制覆盖远程的提交记录。

问题描述

我把一个代码修改提交到了 本地的test分支上,但是我现在想撤回,不想提交了,要怎么办

解决

如果你已经将代码提交到本地的 test 分支上,但现在想撤回提交,有以下几种方式可以选择,具体取决于你是否已经推送了提交到远程仓库。

1. 撤回未推送的提交

如果你提交了代码但还没有推送到远程仓库,想要撤回,可以使用以下方法:

使用 git reset 撤回提交

git reset 可以撤回最近的提交并保留修改在工作区中。

bash 复制代码
git reset --soft HEAD~1
  • --soft:撤销提交,但保留代码变更在暂存区(相当于你还没有 git add 的状态)。
  • HEAD~1:表示回退到当前提交的前一个提交。

结果:

你的提交记录会被撤销,但代码依然存在,可以继续修改或选择不提交。

使用 git reset --hard 完全撤销

如果你不仅想撤回提交,还想丢弃代码修改,可以使用 --hard

bash 复制代码
git reset --hard HEAD~1
  • --hard:不仅撤销提交,还会清除工作区的所有修改。

注意:

使用 --hard 会丢失未保存的修改,所以要谨慎使用。

2. 撤回已经推送到远程的提交

如果你已经将提交推送到远程仓库,还可以撤回提交,但需要使用 git push --force

使用 git reset 回退并强制推送

首先,使用 git reset 撤销本地提交:

bash 复制代码
git reset --soft HEAD~1

然后,强制推送到远程仓库,覆盖已经推送的提交:

bash 复制代码
git push --force

注意:

强制推送会覆盖远程仓库的历史记录,其他开发者如果基于这些提交做了修改,可能会造成问题,所以在多人协作时需要小心使用。


总结:

  • 未推送提交 :可以使用 git reset --soft HEAD~1git reset --hard HEAD~1 来撤回提交,选择保留或丢弃修改。
  • 已推送提交 :可以使用 git reset --soft HEAD~1 后,通过 git push --force 强制覆盖远程的提交记录。
相关推荐
一点事32 分钟前
git:通过令牌方式访问远程仓库
git
或非与2 小时前
windows版本git代码自动更新
git
这是个栗子2 小时前
git报错:‘git‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
git
小生不才yz2 小时前
(二)日常工作流 - git rm 命令的使用
git
inferno3 小时前
TortoiseGit下载与安装
git
取名真是3 小时前
Git 到底是干啥的?零基础小白听完都懂了并且轻松驾驭它
git
AA陈超5 小时前
Git常用命令大全及使用指南
笔记·git·学习
无限进步_5 小时前
C语言数组元素删除算法详解:从基础实现到性能优化
c语言·开发语言·windows·git·算法·github·visual studio
松涛和鸣5 小时前
16、C 语言高级指针与结构体
linux·c语言·开发语言·数据结构·git·算法
楠语5 小时前
从指针行为理解Git中的reset操作
git