IDEA中如何实现git的cherry-pick可视化操作?

news2024/12/26 21:52:19

目录

问题现象:

问题分析:

解决方法:

拓展:如何回退提交记录?


问题现象:

        今天在学习了git的cherry-pick功能,于是引出了一个问题:

        IDEA中如何实现git的cherry-pick可视化操作?


问题分析:

        首先,来了解一下 git 的 cherry-pick 功能是什么?

        1、先说说命令格式:

        git cherry-pick commit记录的id标识

        2、再说功能:

        git cherry-pick:用于把某一个代码分支的commit修改合并到当前的代码分支。

        乍一看,发现和merge有点类似,区别就在于:

        merge:是把某一个代码分支完全合并到当前的代码分支。完全合并的意思就是合并之后,当前分支与被合并的分支的所有文件都是保持完全一致的

        cherry-pick:可以精确地将某一个分支上的某一次commit提交操作的改动,合并到当前代码分支,即合并之后,当前分支与被合并的分支被commit操作改动的文件是保持完全一致的,但其他文件就不一定了。

        3、最后说说好处:

        3.1、当被合并分支存在多个commit提交记录,有时候并不是所有的commit提交记录,都是当前分支所需要的,因此我们可以根据commit提交记录来合并我们实际所需要的即可,这是merge做不到的。

        3.2、以commit记录为单位的合并,可以让当前分支的合并信息更加清晰详细,cherry-pick会默认把commit记录带入合并操作中,可以清晰地知道当前分支中做了什么操作,保证了当前分支和被合并分支的commit记录一致性。而merge则是一次性合并,无法写日志,也无法根据commit记录来清晰地知道当前分支被改动了什么内容,只能通过查看合并记录所影响的文件或被合并分支的commit记录,这样有一定的缺陷。

        不过这也是见仁见智的,因为merge的完全合并确实是省时省力,而cherry-pick则是追求颗粒度。因此 cherry-pick 适用于被合并分支的commit记录较少的时候,例如:
        测试人员会根据每个bug进行问题记录和派发,开发者在收到问题记录后,就需要针对各个bug进行问题消缺,每解决一个bug就commit一次,然后就可以根据下次测试计划中需要验证的bug来对commit记录进行一一cherry-pick。


解决方法:

        1、先保证IDEA底部菜单栏中有 Version Control 项;如果没有可以尝试通过以下2个方法来调出:

        1.1:按快捷键 alt+F9

        1.2:点击顶部菜单栏中的 View - Tool Windows - Version Control

        2、点击底部菜单栏 Version Control - Log ,右下角可以看到我当前分支是(develop),之前我已经提交了几个记录在分支(task/111-001-测试git的stash功能),如图:

        3、选中想要合并的commit记录,右击 - Cherry-Pick :

        弹出窗口后,左边选中本次commit记录所改动的所有文件,右边点击Accept Theirs:

        弹出窗口,可以看到被合并分支的commit记录的日志也被获取过来了,点击Commit and Push:

        弹出提示窗口,大概意思就是说正在解析本次commit合并的代码,右下角可以看到有2 processes running...的字样,这里直接忽略即可,点击Commit:

         commit&push成功:

         至此就实现了IDEA中git的cherry-pick可视化操作?


拓展:如何回退提交记录?

        因为有时候我们误操作了,或者合并错了等等情况,所以这里再提一下如何回滚/回退已提交的记录:

        1、首先要保证commit记录是当前分支的,因为在其他分支的提交记录上操作是无效的:

        2、选中想要回退的commit记录,右击 - Resert

        弹窗commit窗口,这里可以Commit一次,用于记录本次回退操作;也直接关闭或Cancel掉,

 这样就不会记录本次回退操作,这个看实际情况而定吧,反正不管是否提交,都会回退成功

        要是你又误操作了,发现不该回退,或者回退的不该是当前的commit记录,则可以对之前cherry-pick 合并成功之后的commit记录上进行cherry-pick即可,该操作不需要再次commit记录日志,所以非常方便:

         另一种回退操作,Reset Current Branch to Here ,这种是可以把当前分支回滚到历史commit记录中的某个状态:

        弹出窗口,这里我选择了Keep,意思是回退之后,保持当前分支的改动,例如(我现在先创建了一个新文件,之后再点击回退,则回退之后,这个新的文件依然存在,而不会丢失)。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Docker学习教程系列】7-如何将本地的Docker镜像发布到阿里云

在上一篇中,我们使用docker commit 命令,创建了一个带有vim的Ubuntu镜像。那么怎么将这个镜像分享出去呢?本文就来讲解如何将本地的docker镜像发布到阿里云上。 本文主要内容: 1:本地镜像发布到阿里云流程 2&#xf…

Linux网络原理与编程(4)——第十四节 传输层协议

目录 前置知识 再谈端口号 几个函数 netstat telnet UDP报文 UDP协议端格式 UDP首部: UDP的特点 UDP的缓冲区 TCP报文详解 Tcp报头详解 传输层是在应用层的下面一层,我们在讲解传输层协议之前,先来说一说一些前置知识即命令函数等…

看完就会flink基础API

文章目录一、执行环境(Execution Environment)1、创建执行环境2、执行模式(Execution Mode)3、触发程序执行二、源算子(Source)1、数据源类准备2、从集合中读取数据3、从文件中读取数据4、从Socket中读取数据5、从Kafka中读取数据…

ISCSLP 2022 Program|希尔贝壳邀您参加第十三届中文口语语言处理国际会议

第十三届中文口语语言处理国际会议将于2022年12月11-14日(本周日~下周三)正式开启,本次会议中的部分Session将通过语音之家视频号进行线上直播,欢迎大家参加! 官网:www.iscslp2022.org 大会简介 中文口语…

ABAP学习笔记之——第十二章:SALV

一、概要 在Net Weaver 2004 平台上集合了利用函数和 GRID 的功能发布的 SALV 包程序 (SALV也称为 New ALV)。SALV 可以像利用函数生成 ALV 的不用创建屏幕就可以调用的全屏式ALV,还可以利用控制器在屏幕的控制器中显示 ALV。利用GRID 的ALV 虽然不能注册成 Batch …

速卖通知识产权规则介绍,如何才能规避侵权的问题?

最近有商家咨询到我,关于速卖通对商品知识产权是怎么评判的,今天就来给大家科普一下平台关于知识产权的规则介绍 速卖通平台严禁用户未经授权发布、销售涉嫌侵犯第三方知识产权的商品或发布涉嫌侵犯第三方知识产权的信息。 若卖家发布涉嫌侵犯第三方知…

从股票市场选择配对的股票:距离计算方法

我们来看看如何定义距离的计算方法。 回想一下,在共同趋势模型中,协整的必要条件是从共同趋势得到的新息序列必须完全相关。APT中的共同因子回报就理解成是从共同趋势得到的新息序列,因此,新息序列之间的相关系数就是共同因子回报…

网关性能大PK,Spring Cloud Gateway让人大失所望

现在的架构基本都是使用微服务的,而网关作为微服务的统一门户在架构模式中用得越来越多,API网关是所有客户端的单一入口点。 API网关模式是微服务体系结构的一个很好的起点,因为它能够将特定的请求路由到我们从整体上分离的不同服务。事实上…

嘿嘿嘿,10个我经常逛的“小网站”,不骗人

反思一下,为什么你会点进来~ 咳咳,步入正题。 工欲善其事必先利其器,你们的收藏夹里收藏了多少“小网站”?今天和大家分享10个我压箱底的效率工具/平台,现在用不上不要紧,赶紧收藏最关键! 1.G…

【产品设计】APP常见的6种图片浏览模式

六种是指比较常见的图片浏览模式,是在这四种的基础上加上手势来实现另一种读图方式,这里不绝对说就这么几种,那么就谈谈个人对每种图片浏览模式说说自己在实际使用和工作中的一些理解,以及这些模式在实际设计中,哪一种…

智能聊天机器人––ChatGPT初体验

最近几天,由OpenAI公司发布的ChatGPT聊天机器人火了,小杨也怀着对新鲜事物的好奇,亲自体验了一下这个火爆全网,让人沉迷其中无法自拔的ChatGPT聊天机器人,经过体验,我只想用一个字来表达我的感受&#xff0…

【LeetCode每日一题】——142.环形链表 II

文章目录一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【解题思路】七【题目提示】八【题目进阶】九【时间频度】十【代码实现】十一【提交结果】一【题目类别】 链表 二【题目难度】 中等 三【题目编号】 142.环形链表 II 四【题目描述】 …

Java百度地图全套教程(地图找房、轻骑小程序、金运物流等)

课程简介: 本课程基于百度地图技术,将企业项目中地图相关常见应用场景的落地实战,包括有地图找房、轻骑小程序、金运物流等。同时还讲了基于Netty实现高性能的web服务,来处理高并发的问题。 学完本课程能够收获:百度…

支持本地挂载的网盘文件列表工具AList

什么是 Alist? AList 是一个支持多存储的文件列表程序,使用 Gin 框架和 Solidjs 库。可以将常见的 18 种网盘整合在一起,并支持 WebDAV 客户端访问。 之前老苏写过一篇 Alist, 但此 Alist 非彼 Alist,之前的 A 应该是 …

React基础知识(React基本使用、JSX语法、React模块化与组件化)(一)

系列文章目录 文章目录系列文章目录一、React简介1.1 React的特点1.2 React高效的原因二、React基本使用2.1 引入react相关js库2.2 创建虚拟DOM的两种方法2.3 虚拟DOM和真实DOM三、JSX基本使用3.1 jsx使用四、React模块化与组件化4.1 函数式组件4.2 类式组件一、React简介 1.英…

Kafka消费者组消费进度监控

针对Kafka消费者,重要的就是监控消费进度或者是消费的滞后程度,有个专业名词 消费者 Lag 或 Consumer Lag。 滞后程度(Consumer Lag)是指消费者当前落后生产者的程度。比如Kafka 生产者向某主题成功生产了 100 万条消息&#xff0…

一个.NetCore前后端分离、模块化、插件式的通用框架

今天给大家推荐一个基于.NET 6实现的快速开发平台。采用模块化插件式开发,前后端分离,开箱即用。 项目简介 这是一个开箱即用的快速开发平台,前后端分离架构,支持插件式开发,支持工作流、可视化表单功能。系统基础功…

Qt 快速读写Excel指南

Qt Windows 下快速读写Excel指南 很多人搜如何读写excel都会看到用QAxObject来进行操作,很多人试了之后都会发现一个问题,就是慢,非常缓慢!因此很多人得出结论是QAxObject读写excel方法不可取,效率低。 后来我曾试过用…

网络攻击损失不容小觑

据研究数据显示,2022年数据泄露给企业造成的平均损失为435万美元;如果是勒索软件攻击,损失将增加到454万美元。当然这只是估计,在某些国家或地区平均损失更高,比如在美国,损失接近1000万美元。 此外&#x…

如何制作并使用动静态库

制作并使用动静态库🏞️1. 动静态库概念🌁2. 如何制作动静态库📖2.1 制作静态库📖2.2 制作动态库🌠3. 如何使用动静态库📖3.1 使用静态库📖3.2 使用动态库🍁4. 动态库的加载原理&…