当前位置: 首页 > article >正文

撤回仓库的提交

结论先行

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

问题描述

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

解决

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

1. 撤回未推送的提交

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

使用 git reset 撤回提交

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

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

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

使用 git reset --hard 完全撤销

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

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

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

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

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

使用 git reset 回退并强制推送

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

git reset --soft HEAD~1

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

git push --force

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


总结:

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

http://www.kler.cn/a/308344.html

相关文章:

  • Java面向对象高级2
  • ubuntu连接orangepi-zero-2w桌面的几种方法
  • 开发语言中,堆区和栈区的区别
  • 性能测试|JMeter接口与性能测试项目
  • 【MySQL】MySQL函数之JSON_EXTRACT
  • 【数据结构】交换排序——冒泡排序 和 快速排序
  • 基于SpringBoot实现SpringMvc上传下载功能实现
  • uniapp 如何自定义导航栏并自适应机型
  • 【ESP32】ESP-IDF开发 | 中断矩阵+按键输入中断例程
  • 发送成绩的app或小程序推荐
  • PTrade量化服务器连接openapi的地址、key等配置涉及哪些文件?
  • 【学习笔记】SSL密码套件之哈希
  • 【目标检测】labelimg图像标注软件的使用流程
  • 清华镜像源的使用说明
  • 文心一言 VS 讯飞星火 VS chatgpt (349)-- 算法导论23.2 8题
  • AI教你学Python :详解Python元组与集合、字典基础和字符串操作(补充)
  • JavaSE:8、包装类
  • seafaring寻找漏洞
  • 算法入门-贪心1
  • 【React】MobX
  • CI/CD持续集成和持续交付(git工具、gitlab代码仓库、jenkins)
  • DL/T645-2007 通信库(C#版本)
  • 裸金属服务器怎么实现算力共享,裸金属服务器提供者怎么做,租户怎样使用,共享平台需要搭建什么
  • C++11新增特性:lambda表达式、function包装器、bind绑定
  • 在Windows系统中管理苹果磁盘实用工具-使用磁盘,读取磁盘中的文件-供大家学习研究参考
  • 深入解析代理模式:静态代理、JDK 动态代理和 CGLIB 的全方位对比!