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

git 的cherry-pick选择性提交

git cherry-pick 是 Git 中的一个非常有用的命令,它允许你将一个或多个特定的提交(commit)从一个分支应用到另一个分支上,而不是合并整个分支。

单个提交的 cherry-pick

假设你有一个 feature 分支,其中有一个提交(Hash值) abc123,你想要将这个提交应用到 master 分支上。你可以按照以下步骤操作:

  • 切换到目标分支
git checkout master
  • 执行 cherry-pick
git cherry-pick abc123

这条命令会在 master 分支上创建一个新的提交,这个新提交包含与 abc123 相同的更改,但会有一个不同的提交哈希值。

多个提交的 cherry-pick

如果你想要 cherry-pick 多个连续的提交,可以使用下面的语法:

git cherry-pick <HashA>^..<HashB>

注意,这里的 <HashA>^ 表示从 <HashA> 的父提交开始(即不包括 <HashA> 本身),到 <HashB>(包括 <HashB>)之间的所有提交。但是,更常见的做法是直接列出你想要 cherry-pick 的提交哈希值,用空格分隔:

git cherry-pick <HashA> <HashB> <HashC>

这将在当前分支上依次创建 <HashA><HashB> 和 <HashC> 的新提交。

处理合并提交

如果你尝试 cherry-pick 一个合并提交(在 git log 中显示为包含多个父提交的提交),Git 会报错,因为它不知道应该采用哪个父分支的更改。为了解决这个问题,你可以使用 -m 选项来指定合并提交中的一个父分支:

git cherry-pick -m 1 <commitHash>

这里的 -m 1 表示采用合并提交中编号为 1 的父分支的更改。编号从 1 开始,通常 1 表示“主要”或“目标”分支,而 2 表示被合并进来的分支。

解决冲突

在 cherry-pick 过程中,如果新提交的更改与当前分支的更改发生冲突,Git 会停止 cherry-pick 过程,并让你解决冲突。解决冲突后,你需要执行以下命令来继续 cherry-pick 过程:

git add .  # 将解决冲突后的文件添加到暂存区  
git cherry-pick --continue  # 继续 cherry-pick 过程

如果你决定放弃 cherry-pick,可以使用以下命令:

git cherry-pick --abort

这将撤销 cherry-pick 操作,并将工作目录和暂存区恢复到 cherry-pick 之前的状态。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • YOLO主干增强作用及代码
  • OpenCV 车牌检测
  • 第15章 奇异值分解:习题解答及其案例
  • 案例分享:Qt modbusTcp调试工具(读写Byte、Int、DInt、Real、DReal)(当前v1.0.0)
  • html5路由如何在nginx上部署(vite+vue3)
  • 每日一练习(复习昨天的知识)
  • 【VUE基础】VUE3第五节—核心语法之ref标签、props
  • 《警世贤文》摘抄:勤奋篇、取财篇、疏财篇、是非篇、安心篇、防忧篇(多读书、多看报、少吃零食多睡觉)
  • 解析Spring Boot中的数据迁移工具
  • 视频融合共享平台LntonCVS视频监控汇聚平台工业视频监控系统
  • Linux操作系统探索时间
  • 三级嵌入式 汇编指令
  • java使用poi-tl模版引擎导出word之if判断条件的使用
  • css文字自适应宽度动态出现省略号...
  • IO练习网络爬虫获取
  • 【391天】每日项目总结系列128(2018.03.03)
  • Fabric架构演变之路
  • Git的一些常用操作
  • JavaScript HTML DOM
  • java中的hashCode
  • leetcode386. Lexicographical Numbers
  • LeetCode刷题——29. Divide Two Integers(Part 1靠自己)
  • MySQL主从复制读写分离及奇怪的问题
  • PHP面试之三:MySQL数据库
  • 基于遗传算法的优化问题求解
  • 利用阿里云 OSS 搭建私有 Docker 仓库
  • 深入浅出Node.js
  • 远离DoS攻击 Windows Server 2016发布DNS政策
  • 最简单的无缝轮播
  • 摩拜创始人胡玮炜也彻底离开了,共享单车行业还有未来吗? ...
  • 完善智慧办公建设,小熊U租获京东数千万元A+轮融资 ...
  • ​ArcGIS Pro 如何批量删除字段
  • #includecmath
  • #我与Java虚拟机的故事#连载12:一本书带我深入Java领域
  • $$$$GB2312-80区位编码表$$$$
  • (1)(1.11) SiK Radio v2(一)
  • (2)STM32单片机上位机
  • (7)svelte 教程: Props(属性)
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (每日持续更新)jdk api之StringBufferInputStream基础、应用、实战
  • (四)事件系统
  • (太强大了) - Linux 性能监控、测试、优化工具
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • (转)母版页和相对路径
  • (转载)从 Java 代码到 Java 堆
  • (轉貼) 蒼井そら挑戰筋肉擂台 (Misc)
  • ... 是什么 ?... 有什么用处?
  • .net core + vue 搭建前后端分离的框架
  • .NET 应用启用与禁用自动生成绑定重定向 (bindingRedirect),解决不同版本 dll 的依赖问题
  • .NET/ASP.NETMVC 深入剖析 Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(二)...
  • .Net多线程Threading相关详解
  • .net下的富文本编辑器FCKeditor的配置方法
  • /boot 内存空间不够
  • [ 网络通信基础 ]——网络的传输介质(双绞线,光纤,标准,线序)
  • []T 还是 []*T, 这是一个问题