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

新版IDEA中Git的使用(三)

说明:前面介绍了在新版IDEA中Git的基本操作、分支操作,本文介绍一下在新版IDEA中,如何回滚代码;

分以下三个阶段来介绍:

  • 未Commit的文件;

  • 已经Commit,但未push的文件;

  • 已经push的文件;

未Commit

对于未Commit的文件,回滚代码,可以在Commit窗口,选中文件,鼠标右键,选择Rollback,即可回滚代码,恢复到未修改状态;

在这里插入图片描述

弹出窗口,选择Rollback

在这里插入图片描述

文件恢复到未修改状态的黑色;

在这里插入图片描述

而对于新增的文件,直接在Commit界面里删掉即可,当然,也可以选中,Rollback,但文件会加入到未追踪状态,还是会出现在IDEA中,就不如直接删除掉。

在这里插入图片描述

未push

比如,我新增了一个文件、修改了一个文件,提交了,但是还没有push到远程仓库(可以看到分支名后面有箭头),此时我想回滚这次提交;

在这里插入图片描述

可以选择这次提交前面的提交,鼠标右键,点击Reset Current Branch to Here,表示将代码回滚到这次提交的状态;

在这里插入图片描述

点击后,会出现下面几种模式,选择如何处理回退的文件;

在这里插入图片描述

  • Soft:修改的文件、新增的文件都恢复到暂存区;

  • Mixed(默认):修改的文件加入到暂存区,新增的文件恢复到未追踪;

  • Hard:修改的文件、新增的文件都丢失,并且当前分支未commit的文件也恢复(新增的删掉,修改的恢复原样);

  • Keep:修改的文件、新增的文件都丢失,当前分支未commit的文件,新增的文件恢复到未追踪,修改的文件保持原样;

可以根据自己的需要进行选择,选择前想清楚,回退的这部分代码是怎么来的:

  • 如果是push的,那么应该选择Soft、Mixed,避免回退后代码丢失;

  • 如果是pull的,那么应该选择Hard、Keep,避免多出来的代码,影响自己分支;


回滚未push的代码,除此之外,还有以下几种:

在这里插入图片描述

  • Undo Commit…:回滚最近一次提交;

  • Revert Commit:回滚某一次提交,并留下回滚记录;

  • Drop Commit:回滚某一次提交,并不留下回滚记录;

以上操作,均是单次操作的回滚,即仅回滚此次操作的文件,例如A提交创建了文件,B提交修改了文件,如果回滚A提交,B提交中修改的文件就不存在了,就会发生冲突。

已push

例如现在,我将新增的代码,add.txt文件push到远程仓库。push上去后发现这段代码有问题,或者我想修改一下comment内容;

在这里插入图片描述

可以这么做,首先回滚本地的提交;

在这里插入图片描述

修改代码或者修改Comment信息后,再push

在这里插入图片描述

这次选择Push下面的这个操作,Force Push

在这里插入图片描述

选择Force Push

在这里插入图片描述

远程仓库的代码就被本次push冲掉了;

在这里插入图片描述

已经push的提交不推荐使用回滚,建议修改代码、文件后重新push一次。如果该分支有其他同事在push代码,上面这种方法可能会冲掉同事push的代码,有风险。

总结

本文介绍在新版IDEA中Git关于回滚的操作,参考B站UP主【小陈努力码代码】的视频 IDEA小技巧-Git的回滚&&强推&&代码找回

http://www.lryc.cn/news/267017.html

相关文章:

  • node - koa 获取 Content-Type: text/plain 的数据
  • 树形结构
  • 《C++避坑神器·二十四》简单搞懂json文件的读写之根据键值对读写Json
  • SQL进阶理论篇(二十一):基于SQLMap的自动化SQL注入
  • xtu oj 1055 整数分类
  • (2023|CVPR,Corgi,偏移扩散,参数高斯分布,弥合差距)用于文本到图像生成的偏移扩散
  • ACE中为socket增加keepalive策略(windows和linux)
  • 前端工程注入版本号
  • Android 10.0 SystemUI禁用长按recent键的分屏功能
  • 自媒体实战篇:作品爆款三要素的使用场景和重要性
  • Hbase的安装配置
  • VMware17Pro虚拟机安装Linux CentOS 7.9(龙蜥)教程(超详细)
  • QT trimmed和simplified
  • Ensp dhcp全局地址池(配置命令 + 实例)
  • spring aop实际开发中怎么用,Spring Boot整合AOP,spring boot加spring mvc一起使用aop,项目中使用aop
  • C语言操作符if语句好习惯 详解分析操作符(详解4)
  • 【什么是泛型,有什么好处】
  • Stable Diffusion系列(三):网络分类与选择
  • Twincat中PLC的ST语言编程实现机器人安全交互
  • Redis实现日榜|直播间榜单|排行榜|Redis实现日榜01
  • 如何使用内网穿透工具实现Java远程连接本地Elasticsearch搜索分析引擎
  • C语言数据结构-----常用七种排序介绍、分类、实现及性能比较
  • 2023年山东省职业院校技能大赛高职组 “软件测试”赛项竞赛任务四 单元测试
  • 在Redis客户端设置连接密码 并演示密码登录
  • 阿里云公有云平台
  • Zookeeper的学习笔记
  • leetcode2两数加和问题(链表)
  • VSCode中配置prettier和ESLint
  • 如何将本地websocket发布至公网并实现远程访问服务端
  • 分享 | 软件测试的基本流程是什么?软件测试流程详细介绍