Git 如何撤回已 Push 的代码

2023-12-18 23:12
文章标签 代码 push git 撤回

本文主要是介绍Git 如何撤回已 Push 的代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在日常的开发过程中,我们广泛利用Git进行版本控制。然而,有时我们可能会误将错误的代码推送到远程仓库,或者希望在本地返回到先前的某个版本以重新进行开发。
就像我个人的经历一样,我曾推送了一些我认为未来会非常有用的优化方案到线上,但随后又接到了一个紧急的新需求。由于项目的关键性,未经测试的方案不能轻易上线。为了响应新需求,我需要先撤销之前推送的优化方案。
目前我的分支状态如下,我的目标是在本地和远程仓库中都回退到"第四次提交"这一部分。
在这里插入图片描述

方法一、手动删除

对于错误代码较少的情况,通过与想要恢复到的commit进行对比,然后手动删除错误代码是一种有效的方法。只需按住ctrl键选择两个commit,然后点击Compare Versions,即可轻松删除错误代码。这种方法在代码较为简单时非常实用,甚至可以通过再次对比确保代码一致性。
在这里插入图片描述

然而,对于代码较为复杂的情况,对比删除可能变得困难。尤其是涉及到配置文件时,这可能会让人感到困扰。

此外,使用这种方法会保留错误提交的记录,对于追求完美的开发者来说,这可能是一个问题。幸运的是,Git提供了一套更为优雅的操作流程来解决这个问题。

方法二、分支重置

选择你想要重置的分支,选择将当前分支重置到此处,如果是英文则是Reset Current Branch to here
在这里插入图片描述
这时候会跳出四个选项供你选择,我这边选择的是硬模式,也就是hard模式,对于这四种模式,我下面有详细的介绍,如果没有需要可以直接使用硬模式即可
在这里插入图片描述
我们可以看到,第四次提交和第三次提交已经变成白色的了,而且dev分支的标签指向的是第二次提交。
在这里插入图片描述
经过上述操作,本地错误提交的commit已被清除。然而,远程仓库中的提交仍保持原状。为了将本地状态同步到远程仓库,需要删除那些commit。在push界面中,尽管没有新的commit需要提交,但我们需要执行强制推送(Force Push)操作,以确保本地状态推送到远程仓库。
在这里插入图片描述
需要注意的是对于一些被保护的分支,这个操作是不能进行的。需要自行查看配置,一般来说master分支和main分支都是保护分支。我们可以在设置-》版本控制-》git-》推送中查看到

在这里插入图片描述
我们在git上看,dev分支已经还原到第二次提交的这个版本,第三次提交和第四次提交都没了。
在这里插入图片描述

Git Reset 四个参数介绍

这四种模式对应着git reset的四种参数,git官方的文档说明如下

  1. Soft: git reset --soft

Does not touch the index file or the working tree at all (but resets the head to , just like all modes do). This leaves all yourchanged files “Changes to be committed”, as git status would put it.

说明:这将重置索引,但保留工作目录中的文件。这意味着你可以在本地继续编辑文件,而不会丢失已经做出的修改。如果你想回退到某个提交,但同时保留在工作目录中的修改,那么可以使用这个模式。

  1. Mixed: git reset --mixed

Resets the index but not the working tree (i.e., the changed files are preserved but not marked for commit) and reports what has not been updated. This is the default action.

说明:这与 soft 模式类似,但还会清除HEAD指针。这意味着你的本地提交将被丢弃,但你可以继续编辑文件。如果你想丢弃本地的更改,但同时保留在暂存区的更改(还没有添加到索引),那么可以使用这个模式。

  1. Hard: git reset --hard

Resets the index and working tree. Any changes to tracked files in the working tree since are discarded. Any untracked files or directories in the way of writing any tracked files are simply deleted.

说明:这将重置索引和工作目录,并丢弃所有更改。所有的工作都将丢失,相当于你在特定提交的基础上重新开始工作。如果你想丢弃所有的更改,包括工作目录中的文件和暂存区的更改,那么可以使用这个模式。

  1. Keep: git reset --keep

Resets the index and updates the files in the working tree that are different between and HEAD, but keeps those which are different between the index and working tree (i.e. which have changes which have not been added). If a file that is different between and the index has unstaged changes, reset is aborted.

说明:这实际上是一个变体,用于处理Git 2.23及更高版本中引入的合并提交的回退。它尝试保留在重置点之后的所有提交,但丢弃在重置点之前的所有提交。

这篇关于Git 如何撤回已 Push 的代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510086

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

SpringBoot实现图形验证码的示例代码

《SpringBoot实现图形验证码的示例代码》验证码的实现方式有很多,可以由前端实现,也可以由后端进行实现,也有很多的插件和工具包可以使用,在这里,我们使用Hutool提供的小工具实现,本文介绍Sp... 目录项目创建前端代码实现约定前后端交互接口需求分析接口定义Hutool工具实现服务器端代码引入依赖获

利用Python在万圣节实现比心弹窗告白代码

《利用Python在万圣节实现比心弹窗告白代码》:本文主要介绍关于利用Python在万圣节实现比心弹窗告白代码的相关资料,每个弹窗会显示一条温馨提示,程序通过参数方程绘制爱心形状,并使用多线程技术... 目录前言效果预览要点1. 爱心曲线方程2. 显示温馨弹窗函数(详细拆解)2.1 函数定义和延迟机制2.2

Springmvc常用的注解代码示例

《Springmvc常用的注解代码示例》本文介绍了SpringMVC中常用的控制器和请求映射注解,包括@Controller、@RequestMapping等,以及请求参数绑定注解,如@Request... 目录一、控制器与请求映射注解二、请求参数绑定注解三、其他常用注解(扩展)四、注解使用注意事项一、控制

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

VS Code中的Python代码格式化插件示例讲解

《VSCode中的Python代码格式化插件示例讲解》在Java开发过程中,代码的规范性和可读性至关重要,一个团队中如果每个开发者的代码风格各异,会给代码的维护、审查和协作带来极大的困难,这篇文章主... 目录前言如何安装与配置使用建议与技巧如何选择总结前言在 VS Code 中,有几款非常出色的 pyt

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python