IDEA中Git版本回退终极指南:Reset与Revert双方案详解

目录

  • 前言
  • 一、版本回退前置知识
  • 二、Reset方案:整体改写历史
    • 1、IDEA图形化操作(推荐)
      • 1.1、查看提交历史
      • 1.2、选择目标版本
      • 1.3、选择回退模式
        • 1.3.1、Soft(推荐)
        • 1.3.2、Mixed
        • 1.3.3、Hard(慎用)
        • 1.3.4、Keep
      • 1.4、强制推送远程仓库
    • 2、命令行操作
      • 2.1、查看提交记录
      • 2.2、执行回退
      • 2.3、强制同步远程
  • 三、Revert方案:部分撤销提交
    • 1、IDEA图形化操作
      • 1.1、撤销目标提交
      • 1.2、提交新版本
    • 2、命令行操作
  • 总结

前言

  作为开发者,代码版本回退是日常高频操作。IntelliJ IDEA集成了强大的Git工具链,但面对resetrevert两种核心回退方案,许多开发者仍存在选择困惑。本文将解析Reset与Revert两种方案的操作细节及避坑指南。

一、版本回退前置知识

在操作前需明确三个核心概念:工作区 vs 暂存区 vs 仓库

区域本质操作指令场景举例
工作区你正在编辑的代码文件直接修改文件在 UserService.java 中新增代码
暂存区已标记待提交的修改git add将 UserService.java 添加到提交队列
仓库已永久保存的历史版本git commit生成一个版本号为 a1b2c3d 的提交

二、Reset方案:整体改写历史

  通过移动HEAD指针直接回退到目标版本,会删除后续提交记录,适用于本地或需强制同步远程的场景。

1、IDEA图形化操作(推荐)

1.1、查看提交历史

  右键项目 → Git → Show History,或在Log标签页查看所有提交记录。

在这里插入图片描述

1.2、选择目标版本

  右键要回退的提交 → Reset Current Branch to Here(将当前分支重置到此处)。

在这里插入图片描述

1.3、选择回退模式

  单击如上将当前分支重置到此处就会弹窗如下。

在这里插入图片描述

解析每个选项前先看下当前项目在所有状态的文件

在这里插入图片描述

好,四种状态文件已经准备完成,开始展示

1.3.1、Soft(推荐)

  选择Soft回退后,仅移动HEAD指针,所有文件内容没变化。Test1变为修改状态,后续push远程版本回退后,可以选择第一次和第二次的修改内容是否再次提交到远程仓库。

在这里插入图片描述

1.3.2、Mixed

  选择Mixed回退后,所有文件内容没变化(与Soft一样),只是将暂存区Test3移除到工作区,这样看来Soft和Mixed的区别就是清空暂存区。

在这里插入图片描述

1.3.3、Hard(慎用)

  选择Hard回退后,文件内容被还原为第一次提交的状态(Test1第二三提交内容和Test3没提交的内容丢失了),然后暂存区的整个文件Test3丢失(没有像Soft和Mixed转移到工作区),总得来说就是所有本地修改都会丢失(当然不包括工作区Test4,因为还没被git管理)。

  此时还没有push到仓库(后面讲),可以更新代码将Test1第二三提交的内容找回,但是Test2添加的a和Test3的内容则找不回了(因为当时这些内容都在暂存区,然而Hard已经清空暂存区,丢弃了所有修改

在这里插入图片描述

1.3.4、Keep

  选择Keep回退后,回退版本的文件内容被还原为第一次提交的状态(Test1第二三提交内容没了),其他状态的文件内容没有变化(也就是本地修改内容没丢失),但是暂存区文件被移除到工作区

在这里插入图片描述

  这种方式如果回退版本的时候Test1有修改内容,那么回退的时候会弹窗让你选择Test1修改没提交的内容如何处理,类似于解决冲突。(麻烦不推荐)

在这里插入图片描述

总结

  • Soft 回退:当你只想撤回 commit,但不影响文件内容,适用于你希望修改提交内容或者重新提交时使用(推荐

  • Mixed 回退:当你想撤销提交并清理暂存区,但保留文件修改,适用于需要重新整理提交时使用(感觉没用,想保留文件修改可以使用Soft)

  • Hard 回退:当你完全不需要当前工作和暂存区的修改,并且想彻底恢复到某个提交时使用,慎用,因为无法恢复丢失的内容(保证本地所有修改内容都没用可以使用

  • Keep 回退:当你希望恢复到某个提交的版本,但又不丢失本地修改时使用(恢复版本的文件的本地内容需要手动选择要还是丢,麻烦不推荐)

1.4、强制推送远程仓库

  • 回退后本地仓库版本低于远程,需执行强制推送
  • 在强制推送远程仓库前,都可以通过更新代码恢复上面的版本回退

方式一(不推荐)

  git push --force 是强制推送命令,它会将本地分支的内容强行推送到远程仓库,覆盖远程分支的历史记录。使用此命令时,如果远程分支的提交历史与本地分支不同,推送操作仍会进行,并且不会进行任何检查,可能会丢失远程仓库中的更改。因此,这个命令需要小心使用,尤其在多人协作的情况下,可能会覆盖他人的更改。

git push --force
# 等同于 
git push -f

方式二(推荐)

  git push --force-with-lease--force 的更安全版本。它会先检查远程分支是否被其他人更新,若有变动则推送失败并提示,避免覆盖他人更改。该命令会自动推送当前分支到远程仓库对应的分支。

git push --force-with-lease   # 推荐,避免覆盖他人提交

2、命令行操作

2.1、查看提交记录

方式一

git log 

在这里插入图片描述

方式二

git log --oneline   # 获取目标commit_id(前7位即可)

在这里插入图片描述

方式三

idea中直接选择历史版本右击选择复制修订号

在这里插入图片描述

2.2、执行回退

三种不同的回退模式,上面已经详细介绍了

# 彻底回退(删除工作区+暂存区修改)
git reset --hard 62b47d9   # 回退到上一个提交(保留工作区修改)
git reset --soft HEAD\~1   # 回退到前2个版本(保留工作区,暂存区重置)
git reset --mixed HEAD^^   

2.3、强制同步远程

这里与IDEA图形化操作命令一样

git push --force-with-lease   # 推荐,避免覆盖他人提交git push -f origin master   # 强制覆盖远程分支

三、Revert方案:部分撤销提交

  生成新的提交记录逆向操作目标版本,保留完整历史链,适合团队协作或需审计的场景。

1、IDEA图形化操作

1.1、撤销目标提交

仅仅撤销本次提交历史的内容,如果此版本后面又添加了b,此次撤销就需要解决冲突了。

在这里插入图片描述

1.2、提交新版本

自动生成Revert "原提交信息"的新提交,需要推送至远程(相当于我们手动点进这个文件,把添加a的代码删除,然后提交推送)

在这里插入图片描述

2、命令行操作

# 撤销单个提交
git revert 62b47d9  
# 推送当前分支到远程仓库
git push origin 分支

总结

  Git版本回退有两种主要方案:Reset通过移动HEAD指针直接回退,适用于本地或强制同步远程,Revert通过生成新的提交逆向撤销,适合团队协作并保留历史记录;根据需求选择合适方式并谨慎操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/29367.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试题02.02.返回倒数第k个节点

实现一种算法,找出单向链表中倒数第 k 个节点。返回该节点的值。 注意:本题相对原题稍作改动 示例: 输入: 1->2->3->4->5 和 k 2 输出: 4 说明: 给定的 k 保证是有效的。 题解&#xff…

【经验分享】Ubuntu20.04编译RK3568 AI模型报错问题(已解决)

【经验分享】Ubuntu20.04编译RK3568 AI模型报错问题(已解决) 前言问题现象问题分析解决方案总结 前言 这里使用的是Rockchip提供的rknn_model_zoo,https://github.com/airockchip/rknn_model_zoo/tree/main 此解决方案适用于Rockchip芯片在U…

Python的那些事第四十一篇:简化数据库交互的利器Django ORM

Django ORM:简化数据库交互的利器 摘要 随着互联网技术的飞速发展,Web开发越来越受到重视。Django作为一款流行的Python Web框架,以其高效、安全、可扩展等特点受到了广大开发者的喜爱。其中,Django ORM(对象关系映射)是Django框架的核心组件之一,它为开发者提供了一种…

Swagger UI界面的使用

访问地址 一般格式:http://xxxx:端口号/上下文路径/swagger-ui/index.html 首先保证当前项目已经集成Swagger的功能 上下文路径:指的配置文件中的:server.servlet.context-path的值 刚进入界面,找到自己的服务接口,开…

WPS工具栏添加Mathtype加载项

问题描述: 分别安装好WPS和MathType之后,WPS工具栏没直接显示MathType工具,或者是前期使用正常,由于WPS更新之后MathType工具消失,如下图 解决办法 将文件“MathType Commands 2016.dotm”和“MathPage.wll”从Matht…

部署RabbitMQ集群详细教程

部署RabbitMQ集群详细教程 下面是一份在 Ubuntu 环境下部署 RabbitMQ 集群的详细步骤说明,涉及主机名设置、Erlang & RabbitMQ 安装、管理插件启用、集群通信 Cookie 配置、节点加入集群、镜像队列策略设置以及集群验证等。为了演示方便,以下示例假…

三维数据可视化与表面重建:Marching Cubes算法的原理与应用

1. 引言 随着现代医学影像技术的飞速发展,三维数据的可视化与重建已成为医学研究、临床诊断和手术规划的重要工具。在众多三维重建算法中,Marching Cubes算法因其高效、稳定的特性成为从离散数据场中提取等值面的经典方法。本报告将深入探讨Marching Cu…

IDEA 2024.1.7 Java EE 无框架配置servlet

1、创建一个目录(文件夹)lib来放置我们的库 2、将tomcat目录下的lib文件夹中的servlet-api.jar文件复制到刚创建的lib文件夹下。 3、把刚才复制到lib下的servlet-api.jar添加为库 4、在src下新建一个package:com.demo,然后创…

【文生图】windows 部署stable-diffusion-webui

windows 部署stable-diffusion-webui AUTOMATIC1111 stable-diffusion-webui Detailed feature showcase with images: 带图片的详细功能展示: Original txt2img and img2img modes 原始的 txt2img 和 img2img 模式 One click install and run script (but you still must i…

【TCP/IP协议栈】【传输层】端口号、套接字、多路复用/分解、网络字节序

参考资料: 前言: 总结: 【计算机网络】套接字(应用层和传输层之间的接口) 套接字是一个通用的通信接口抽象不仅限于TCP/IP协议族作为应用层和传输层之间的桥梁支持多种通信方式和协议族 套接字定义 在 TCP 或者 UDP…

【AI大模型】DeepSeek + Kimi 高效制作PPT实战详解

目录 一、前言 二、传统 PPT 制作问题 2.1 传统方式制作 PPT 2.2 AI 大模型辅助制作 PPT 2.3 适用场景对比分析 2.4 最佳实践与推荐 三、DeepSeek Kimi 高效制作PPT操作实践 3.1 Kimi 简介 3.2 DeepSeek Kimi 制作PPT优势 3.2.1 DeepSeek 优势 3.2.2 Kimi 制作PPT优…

【哇! C++】类和对象(三) - 构造函数和析构函数

目录 一、构造函数 1.1 构造函数的引入 1.2 构造函数的定义和语法 1.2.1 无参构造函数: 1.2.2 带参构造函数 1.3 构造函数的特性 1.4 默认构造函数 二、析构函数 2.1 析构函数的概念 2.2 特性 如果一个类中什么成员都没有,简称为空类。 空类中…

基于RapidOCR与DeepSeek的智能表格转换技术实践

基于RapidOCR与DeepSeek的智能表格转换技术实践 一、技术背景与需求场景 在金融分析、数据报表处理等领域,存在大量图片格式的表格数据需要结构化处理。本文介绍基于开源RapidOCR表格识别与DeepSeek大模型的智能转换方案,实现以下典型场景: …

字节跳动AI原生编程工具Trae和百度“三大开发神器”AgentBuilder、AppBuilder、ModelBuilder的区别是?

字节跳动AI编程工具Trae与百度"三大开发神器"(AgentBuilder、AppBuilder、ModelBuilder)在定位、功能架构和技术路线上存在显著差异,具体区别如下: 一、核心定位差异 Trae:AI原生集成开发环境(AI…

docker:Dockerfile案例之自定义centos7镜像

1 案例需求 自定义centos7镜像。要求&#xff1a; 默认登录路径为 /usr可以使用vim 2 实施步骤 编写dockerfile脚本 vim centos_dockerfile 内容如下&#xff1a; #定义父镜像 FROM centos:7#定义作者信息 MAINTAINER handsome <handsomehandsome.com># 设置阿里云…

【音视频】ffplay简单过滤器

一、ffplay简单过滤器 视频旋转&#xff1a;借助transpose滤镜 ffplay -i 1.mp4 -vf transpose1这里选择不同的数字是不同的方向&#xff1a; 视频翻转&#xff1a;借助hflip/vflip实现水平和垂直翻转&#xff1a; 水平翻转 ffplay 1.mp4 -vf hflip垂直翻转 ffplay 1.mp4 …

使用Kingfisher加载网络图片时使用indicatorType产生布局混乱

SheetInfoCell代码中&#xff0c;执行iconView.show(info.picurl) 时&#xff0c;若采用kf.indicatorType .activity&#xff0c;则会产生ui页面混乱&#xff0c;如果不使用这个加载动画&#xff0c;则不会产生。 与此同时&#xff0c;对于发现页面&#xff0c;是否使用加载动…

【慕课网wiki项目学习笔记01】Spring Boot 项目搭建

2-2 新建SpringBoot项目 一、创建SpringBoot项目 &#xff08;1&#xff09;在SpringBoot官网创建 &#xff08;2.1&#xff09;在 IDEA 中创建 Group&#xff1a;公司名 Artifact&#xff1a;项目名 创建成功后开始下载Maven依赖&#xff08;选择右下角的Import Changes&…

突破极限:高性能ROCK 220A-M 工业级无人机电调深度测评 —— 无人机动力系统的核心守护者

引言 在无人机技术高速发展的今天&#xff0c;动力系统的稳定性与效率成为决定任务成败的关键。作为工业级电调领域的标杆产品&#xff0c;ROCK 220A-M 凭借其卓越的性能与多重安全设计&#xff0c;为专业级无人机应用提供了可靠的动力解决方案。本文将从技术架构、防护…

Java-servlet(三)Java-servlet-Web环境搭建(下)详细讲解利用maven和tomcat搭建Java-servlet环境

Java-servlet&#xff08;三&#xff09;Java-servlet-Web环境搭建&#xff08;下&#xff09;利用maven和tomcat搭建Java-servlet环境 前言一、配置maven阿里镜像二、利用IDEA创建maven文件创建maven文件删除src文件创建新的src模版删除example以及org文件 三、在第二个xml文件…