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

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...