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

GIt分支合并

分支 1: C0 → C1 → C2 → C3(最新)
分支 2: C0 → C4 → C5 → C6(最新)

1. 找到共同父节点 C0

Git 会先找出 branch1branch2 的共同祖先节点 C0。这通常借助 git merge-base 命令达成,虽然在日常使用 git merge 时不需要手动执行该命令,但 Git 内部会自动完成这个操作:

# 手动获取共同父节点(仅用于演示原理)
common_ancestor=$(git merge-base branch1 branch2)

2. 计算差异

Git 会分别计算 branch1branch2 相对于共同父节点 C0 的差异。它采用的是一种基于内容的差异算法,也就是找出文件内容在不同版本之间的变化。具体来说:

  • 对于 branch1,Git 会分析从 C0branch1 最新提交 C1 期间文件内容的改动,例如哪些文件被新增、修改或者删除。
  • 对于 branch2,Git 会分析从 C0branch2 最新提交 C2 期间文件内容的改动。

3. 应用差异

接下来,Git 会尝试把 branch1 相对于 C0 的差异应用到 branch2 上。这一过程可以分为以下几种情况:

无冲突情况

如果 branch1branch2 的修改没有重叠,也就是没有对同一文件的同一部分进行修改,Git 会直接将 branch1 的修改合并到 branch2 中。例如:

  • 新增文件:如果 branch1 相对于 C0 新增了一个文件,Git 会在 branch2 中也创建这个文件,并将其内容复制过来。
  • 修改文件:如果 branch1 对某个文件进行了修改,而 branch2 没有对该文件进行修改,Git 会把 branch1 对该文件的修改应用到 branch2 对应的文件上。
  • 删除文件:如果 branch1 相对于 C0 删除了一个文件,而 branch2 没有对该文件进行修改,Git 会在 branch2 中也删除这个文件。
有冲突情况

branch1branch2 对同一文件的同一部分进行了不同的修改时,就会产生冲突。Git 无法自动决定采用哪个修改,因此会在冲突的文件中标记出冲突的部分。例如,文件中会出现类似如下的冲突标记:

<<<<<<< HEAD
这是 branch2 中的内容
=======
这是 branch1 中的内容
>>>>>>> branch1

<<<<<<< HEAD 表示当前分支(即 branch2)的内容,======= 是分隔符,>>>>>>> branch1 表示要合并进来的分支(即 branch1)的内容。此时需要手动编辑这些内容,选择保留哪些部分,或者将两部分内容进行整合。

4. 创建合并提交

无论是否有冲突,在完成差异应用后,Git 都会创建一个新的合并提交。这个合并提交有两个父节点,分别是 branch2 的最新提交 C2branch1 的最新提交 C1。合并提交记录了合并操作的结果,将两个分支的修改整合到了一起。可以使用以下命令查看合并提交的信息:

git log --graph --oneline --all

综上所述,Git 通过找到共同父节点、计算差异、应用差异和创建合并提交这几个步骤,实现了将 branch1 相对于 C0 的差异应用到 branch2 上的操作。

简单来说,合并的分支与当前分支必定会有共同的父节点,git会依次执行要合并的分支上的每一次提交,最终与当前分支的最新一次提交一起生成一次新的提交。

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

相关文章:

  • Sqli-labs
  • unreal engine gameplay abiliity 获取ability的cooldown剩余时间
  • 【GenBI优化】提升text2sql准确率:建议使用推理大模型,增加重试
  • 【六祎 - Note】SQL备忘录;DDL,DML,DQL,DCL
  • 高频 SQL 50 题(基础版)_1341. 电影评分
  • JavaScript 变量命名规范
  • 解决 uView-UI和uv-ui 中 u-tabs 组件在微信小程序中出现横向滚动条的问题
  • 20250304解决在飞凌的OK3588-C的Linux R4下解决使用gstreamer保存的mp4打不开
  • build gcc
  • 【每日论文】How far can we go with ImageNet for Text-to-Image generation?
  • STM32 两个单片机之间的通信
  • Linux 下使用traceroute来进行网络诊断分析
  • 基于vue框架的游戏商城系统cq070(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • SpringBoot接入DeepSeek(硅基流动版)+ 前端页面调试(WebSocket连接模式)
  • idea实现热部署
  • 记一次误禁用USB导致键盘鼠标失灵的修复过程
  • 0x03 http协议和分层架构
  • 【leetcode hot 100 189】轮转数组
  • 医药行业哪些招聘管理系统有AI功能?
  • .net8 使用 license 证书授权案例解析
  • golang的io
  • 全向广播扬声器在油气田中的关键应用 全方位守护安全
  • 76.读取计时器运行时间 C#例子 WPF例子
  • 嵌入式开发:傅里叶变换(5):基于STM32,实现CMSIS中的DSP库
  • 探秘基带算法:从原理到5G时代的通信变革【六】CRC 校验
  • MySQL——DQL、多表设计
  • XML 编辑器:全面指南与最佳实践
  • 【USRP】NVIDIA Sionna:用于 6G 物理层研究的开源库
  • DeepSeek开源周Day6:DeepSeek V3、R1 推理系统深度解析,技术突破与行业启示
  • intra-mart实现logicDesigner与forma联动