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

git中的merge和rebase的区别

在 Git 中,git merge 和 git rebase 都是用于整合分支变更的核心命令,但它们的实现方式和结果有本质区别。以下是两者的详细对比:


一、核心区别

特性git mergegit rebase
历史记录保留分支拓扑,生成新的合并提交线性化历史,复制提交到目标分支的末端
提交树结构创建分叉(Merge Commit保持线性(无分叉)
适用场景公共分支(如 maindevelop本地开发分支(未共享的分支)
冲突处理冲突解决后生成合并提交冲突在变基过程中逐提交解决
历史可追溯性保留分支合并的上下文隐藏分支开发细节,简化历史
对协作的影响安全(不修改公共提交历史)危险(重写历史,破坏他人分支)

二、工作流程对比

1. git merge 的流程
  • 目标:将分支 feature 合并到 main

  • 操作

    git checkout main
    git merge feature
  • 结果

    *   合并提交 (main)
    |\  
    | * 提交 C (feature)
    | * 提交 B
    |/  
    * 提交 A (初始提交)
2. git rebase 的流程
  • 目标:将 feature 的提交变基到 main 的最新提交。

  • 操作

    git checkout feature
    git rebase main
    git checkout main
    git merge feature  # 快进合并(Fast-forward)
  • 结果

    * 提交 C' (feature → main)
    * 提交 B'
    * 提交 A (main 的最新提交)

三、适用场景

1. 何时使用 git merge
  • 公共分支整合(如合并 feature 到 main)。

  • 保留分支历史(需要明确看到合并时间点)。

  • 团队协作(避免因重写历史导致冲突)。

2. 何时使用 git rebase
  • 本地分支整理(清理中间提交,合并 fixup)。

  • 保持线性历史(避免不必要的合并提交)。

  • 同步上游分支(如将 main 的更新整合到开发分支)。


四、命令详解

1. git merge
  • 合并策略

    • 快进合并(Fast-forward):如果目标分支是源分支的直接祖先,直接移动指针。

    • 三方合并(Three-way Merge):创建新的合并提交(非快进时)。

  • 常用选项

    git merge --no-ff  # 强制生成合并提交(即使可快进)
    git merge --abort  # 终止合并(冲突时)
2. git rebase
  • 操作步骤

    1. 找到当前分支和目标分支的最近公共祖先。

    2. 提取当前分支的差异提交。

    3. 将这些提交按顺序应用到目标分支的最新提交后。

    4. 移动分支指针到新提交链的末端。

  • 常用选项

    git rebase -i HEAD~3  # 交互式变基(合并/修改提交)
    git rebase --continue # 解决冲突后继续变基
    git rebase --abort    # 终止变基

五、优缺点对比

特性git merge 优点git merge 缺点
历史清晰度明确保留分支合并关系历史可能复杂(多分叉)
协作友好性不修改公共历史,适合团队协作合并提交可能冗余
冲突处理一次性解决所有冲突合并提交可能包含不相关修改
历史清晰度提交历史线性化,易于阅读隐藏分支开发细节
协作友好性适合本地分支整理重写历史可能破坏他人分支
冲突处理逐提交解决冲突(更精细)可能需要多次解决相同冲突

六、最佳实践

  1. 公共分支用 merge,私有分支用 rebase

    • main/develop 分支使用 merge 保留合并记录。

    • 本地 feature 分支在合并前用 rebase 整理提交。

  2. 禁止对已推送的分支执行 rebase

    • 重写公共历史会导致协作混乱。

  3. 交互式变基(rebase -i)优化提交

    • 合并冗余提交(squash)、修改提交消息(reword)。

  4. 同步上游分支时优先 rebase

    git pull --rebase  # 等同于 fetch + rebase(而非 merge)

七、总结

核心选择git mergegit rebase
历史风格非线性的真实历史线性化的整洁历史
协作影响安全需谨慎使用
适用阶段分支合并到公共主干本地分支整理

黄金法则
已推送的分支用 merge,未推送的分支用 rebase
通过合理选择合并策略,可以兼顾历史可读性和协作安全性。

相关文章:

git中的merge和rebase的区别

在 Git 中,git merge 和 git rebase 都是用于整合分支变更的核心命令,但它们的实现方式和结果有本质区别。以下是两者的详细对比: 一、核心区别 特性git mergegit rebase历史记录保留分支拓扑,生成新的合并提交线性化历史&#x…...

【目标检测】目标检测中的数据增强终极指南:从原理到实战,用Python解锁模型性能提升密码(附YOLOv5实战代码)

🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...

uniapp在app下使用mqtt协议!!!支持vue3

什么?打包空白?分享一下我的解决方法! 第一步 找大师算过了,装4.1版本运气好! 所以根目录执行命令… npm install mqtt4.1.0第二步 自己封装一个mqtt文件方便后期开坛做法! // utils/mqtt.js import mqt…...

VMware虚拟机17.5.2版本下载与安装(详细图文教程包含安装包)

文章目录 前言一、vmware虚拟机下载二、vmware虚拟机安装教程三、vmware虚拟机许可证 前言 VMware Workstation Pro 17 功能强大,广受青睐。本教程将带你一步步完成它的安装,简单易上手,助你快速搭建使用环境。 一、vmware虚拟机下载 VMwar…...

如何加固织梦CMS安全,防webshell、防篡改、防劫持,提升DedeCMS漏洞防护能力

织梦系统(DedeCMS)是一款非常知名的CMS系统,因其功能强大、结构科学合理,深受广大用户喜欢。 虽然织梦CMS(DedeCMS)非常优秀,但是为了保障网站安全,我们还是需要做一些必要的防护措…...

STM32的HAL库开发---ADC采集内部温度传感器

一、STM32内部温度传感器简介 二、温度计算方法 F1系列: 从数据手册中可以找到V25和Avg_Slope F4、F7、H7系列只是标准值不同,自行查阅手册 三、实验简要 1、功能描述 通过ADC1通道16采集芯片内部温度传感器的电压,将电压值换算成温度后&…...

Linux 命令大全完整版(12)

Linux 命令大全 5. 文件管理命令 ln(link) 功能说明&#xff1a;连接文件或目录。语  法&#xff1a;ln [-bdfinsv][-S <字尾备份字符串>][-V <备份方式>][--help][--version][源文件或目录][目标文件或目录] 或 ln [-bdfinsv][-S <字尾备份字符串>][-V…...

Python - 代码片段分享 - Excel 数据实时写入方法

文章目录 前言注意事项工具 pandas1. 简介2. 安装方式3. 简单介绍几个api 实战片段 - 实时写入Excel文件结束语 要么出众&#xff0c;要么出局 前言 我们在爬虫采集过程中&#xff0c;总是将数据解析抓取后统一写入Excel表格文件&#xff0c;如果在解析数据出现问题容易出现数据…...

(七)趣学设计模式 之 适配器模式!

目录 一、 啥是适配器模式&#xff1f;二、 为什么要用适配器模式&#xff1f;三、 适配器模式的实现方式1. 类适配器模式&#xff08;继承插座 &#x1f468;‍&#x1f469;‍&#x1f467;‍&#x1f466;&#xff09;2. 对象适配器模式&#xff08;插座转换器 &#x1f50c…...

DeepSeek 细节之 MoE

DeepSeek 细节之 MoE DeepSeek 团队通过引入 MoE&#xff08;Mixture of Experts&#xff0c;混合专家&#xff09; 机制&#xff0c;以“分而治之”的思想&#xff0c;在模型容量与推理成本之间找到了精妙的平衡点&#xff0c;其中的技术实现和细节值得剖思 Transformer 演变…...

【Linux-网络】从逻辑寻址到物理传输:解构IP协议与ARP协议的跨层协作

&#x1f3ac; 个人主页&#xff1a;谁在夜里看海. &#x1f4d6; 个人专栏&#xff1a;《C系列》《Linux系列》《算法系列》 ⛰️ 道阻且长&#xff0c;行则将至 目录 &#x1f4da;前言 &#x1f4d6; IP地址的组成 &#x1f516;IPv4 &#x1f516;IPv6 &#x1f4da…...

毕业离校管理系统的开发与需求分析

在当今信息化的时代背景下&#xff0c;高校的毕业生离校管理工作也逐渐向数字化转型。为了提高工作效率&#xff0c;减少人为错误&#xff0c;增强信息透明度&#xff0c;毕业离校管理系统应运而生。该系统旨在为学校提供一个高效、准确的毕业生离校管理平台&#xff0c;从而提…...

【NLP 24、实践 ⑤ 计算Bert模型中的参数数量】

以前不甘心&#xff0c;总想争个对错&#xff0c;现在不会了 人心各有所愿&#xff0c;没有道理可讲 —— 25.1.18 计算Bert模型结构中的参数数量 BertModel.from_pretrained()&#xff1a;用于从预训练模型目录或 Hugging Face 模型库加载 BERT 模型的权重及配置。 参数名称…...

一、Spring框架系统化学习路径

系统化的Spring框架学习路径 第1阶段&#xff1a;基础知识准备 Java基础 核心概念&#xff1a;面向对象、异常处理、集合框架、多线程等。JVM基础&#xff1a;内存模型、垃圾回收机制。 Maven或Gradle Maven&#xff1a;创建项目、依赖管理、生命周期。Gradle&#xff1a;基本…...

Midscene.js - AI驱动,轻松实现UI自动化

UI自动化测试一直是软件测试中的一项重要任务&#xff0c;而随着AI技术的快速发展&#xff0c;自动化测试的能力也在不断提升。如何让UI自动化更智能、精准、灵活&#xff1f;Midscene.js作为一款AI驱动的UI自动化测试工具&#xff0c;正逐步改变着传统自动化测试的面貌。你是不…...

(九)Mapbox GL JS 中 Marker 图层的使用详解

什么是 Marker&#xff1f; 在 Mapbox GL JS 中&#xff0c;Marker&#xff08;标记&#xff09; 是一个可视化元素&#xff0c;用于在地图上标记特定的地理位置。它可以是一个默认的图标、自定义的图像&#xff0c;或者任何 HTML 元素。Marker 不仅能显示位置&#xff0c;还能…...

2k1000LA 使能 nand.

背景 : 默认的 发货的镜像 确实 是识别不了 nand 的。 ------------------------------------------------------------------------------------------ 但是 我之前 已经写好了文档,因此 拷贝到线上。 1 首先我要使能这几个。 在menuconfig 中使能一下。...

Junit+Mock

base project <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.6.11</version><relativePath/></parent><dependencies><!--添加mysql依…...

maven编译出错,javac: ��Ч��Ŀ�귢�а�: 17

1、异常信息 javac: &#xfffd;&#xfffd;Ч&#xfffd;&#xfffd;Ŀ&#xfffd;귢&#xfffd;а&#xfffd;: 17 &#xfffd;&#xfffd;: javac <options> <source files> -help &#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;г&a…...

Vue使用Three.js加载glb (gltf) 文件模型及实现简单的选中高亮、测距、测面积

安装&#xff1a; # three.jsnpm install --save three 附中文网&#xff1a; 5. gltf不同文件形式(.glb) | Three.js中文网 附官网&#xff1a; 安装 – three.js docs 完整代码&#xff08;简易demo&#xff09;&#xff1a; <template><div class"siteInspe…...

知识图谱化技术实体链接与知识推理的实现

知识图谱化技术&#xff1a;实体链接与知识推理的实现 在当今大数据时代&#xff0c;知识图谱作为结构化知识的重要载体&#xff0c;广泛应用于搜索引擎、智能问答和推荐系统等领域。其中&#xff0c;实体链接与知识推理是知识图谱构建与应用的核心技术。实体链接旨在将文本中…...

从E·M·福斯特的《英国人性格的笔记》看技术文档写作:如何避免“未发育的心”与“自满的陷阱”

技术文档写作中的文化共情&#xff1a;如何跨越"情感表达鸿沟" 当一份API文档被翻译成八种语言却依然收到用户投诉时&#xff0c;当技术博客的评论区频繁出现"冷漠"、"难以理解"的评价时&#xff0c;我们或许需要思考一个更深层的问题&#xff1…...

C# Winform实战:手把手教你实现一个带右键菜单的截图OCR工具(附百度AI Key申请指南)

C# Winform实战&#xff1a;打造智能截图OCR工具的全流程解析 在信息爆炸的时代&#xff0c;我们每天都会遇到需要快速提取图片中文字的场景——可能是网页上的付费内容、纸质文档的电子化&#xff0c;或是会议白板上的灵感记录。传统的手动输入效率低下&#xff0c;而现有工具…...

51单片机printf重定向避坑指南:为什么你的printf卡死了?

51单片机printf重定向避坑指南&#xff1a;为什么你的printf卡死了&#xff1f; 当你第一次在51单片机项目中使用printf函数时&#xff0c;可能会遇到一个令人困惑的现象&#xff1a;程序莫名其妙地卡死了&#xff0c;没有任何输出。这种情况在初学者中非常常见&#xff0c;而问…...

从LSTM到LLM-to-Action:SITS2026发布游戏智能演进年表(2018–2026),标注3次范式跃迁时刻及对应算力/数据拐点)

第一章&#xff1a;SITS2026分享&#xff1a;AGI与游戏智能 2026奇点智能技术大会(https://ml-summit.org) AGI在游戏环境中的验证价值 通用人工智能&#xff08;AGI&#xff09;并非仅面向抽象推理任务&#xff0c;游戏世界正成为其核心验证场域。开放世界RPG、实时策略与多…...

告别第三方API:SpringBoot项目集成ip2region离线IP库的完整配置流程(附工具类)

SpringBoot深度整合ip2region&#xff1a;从离线IP定位到微服务架构实践 在Web应用开发中&#xff0c;获取用户地理位置信息是常见的需求场景。无论是内容分发、风控系统还是数据分析&#xff0c;IP属地信息都能为业务决策提供重要参考。传统方案通常依赖第三方API服务&#xf…...

如何高效使用ComfyUI-Inpaint-CropAndStitch:智能局部修复技术完全指南

如何高效使用ComfyUI-Inpaint-CropAndStitch&#xff1a;智能局部修复技术完全指南 【免费下载链接】ComfyUI-Inpaint-CropAndStitch ComfyUI nodes to crop before sampling and stitch back after sampling that speed up inpainting 项目地址: https://gitcode.com/gh_mir…...

BLE协议栈探秘:从ATT属性表到GATT服务树的通信逻辑

1. BLE通信的基础架构&#xff1a;从广播到连接 想象一下你走进一家咖啡馆&#xff0c;手机自动弹出了当前可连接的Wi-Fi列表——这个场景和BLE设备建立连接的过程非常相似。BLE&#xff08;蓝牙低功耗&#xff09;技术之所以能成为物联网设备的标配&#xff0c;关键在于它精巧…...

[具身智能-394]:机器人运动控制单元功能概述与主要技术栈

机器人运动控制单元是机器人系统的“小脑”与“中枢神经”&#xff0c;其核心职责是将高层的任务指令&#xff08;如“抓取物体”、“移动到B点”&#xff09;转化为驱动执行机构&#xff08;如电机&#xff09;的精确物理动作。它通过协调控制位置、速度、加速度和力矩&#x…...

保姆级教程:手把手教你搞定吉比特GM228-S光猫桥接,让路由器真正当家做主

家庭网络性能优化实战&#xff1a;光猫桥接与路由器拨号全解析 你是否遇到过这样的困扰——明明升级了千兆宽带&#xff0c;但实际下载速度却始终不达标&#xff1f;在线视频频繁缓冲、游戏延迟居高不下&#xff0c;即使更换了高端路由器也无济于事&#xff1f;问题的根源可能就…...