Git(5):分支合并merge和rebase

git merge

假设有两个分支:master 分支和 feature 分支,现在需要将 feature 分支合并到 master 分支。

git checkout mastergit merge feature

在合并分支时,git 提供了不同的合并策略,用于处理不同的合并场景。

  • Fast-forward

    如果源分支(feature)与目标分支(master)之间没有分叉,即 master 分支在上次同步之后没有新的提交,那么当执行 git merge feature 时,git 会直接将 master 分支的指针移动到feature 分支的最新提交上,而不会创建新的合并提交。

合并前:

在这里插入图片描述
进行合并:

在这里插入图片描述

合并后:
在这里插入图片描述
快速合并不生成单独的合并提示从而不会留下合并痕迹,所以可以使用 git merge --no-ff feature 强制 git 在合并时创建一个新的合并提交。

  • --no-ff

    如果 master 分支与 feature 分支之间存在分叉,即 master 分支产生了新的提交 M,此时无法快速合并,会采用 no-ff 方式进行合并,创建一个新的合并提示。如果两个分支存在代码冲突,需要先解决冲突再合并。

    合并前:
    在这里插入图片描述
    合并后:

在这里插入图片描述

这样,合并后的历史就不再是线性的,而是包含了一个明确的合并点。

git rebase

git rebase 用于将当前分支的更新重新应用到另一个分支的最新更新上,使得项目历史更加线性。

假设有两个分支:master 分支和 feature 分支。master 是主分支,feature 是从 master 分支的某个提交点拉出的功能分支。现在,master 分支上有了新的提交,我们想要在保持 feature 分支更改的同时,将这些更改重新应用到 master 分支的最新状态上。

变基前:
在这里插入图片描述
以 master 分支为基,对 feautre 分支进行变基:

意味着将 feature 分支上的所有提交按照顺序重新应用到 master 分支的最新提交上。这个操作会改变 feature 分支的提交历史,使其看起来像是直接在 master 分支的最新状态上进行的开发。

git checkout feature
git rebase master

可以简写为 git rebase master feature

在变基过程中,如果 git 发现 feature 分支上的某个提交与 master 分支上的某个提交存在冲突,它会暂停变基过程,并让你手动解决这些冲突。解决冲突后,你需要使用 git add 命令将解决冲突后的文件添加到暂存区,然后使用 git rebase --continue 命令继续变基操作。

变基后:
在这里插入图片描述
rebase 操作过程中,只有当前分支(feature)的操作历史会被改变,而基分支(master)的操作历史不会变化。

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

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

相关文章

《百家姓》中排名第八却是中国人口第一大姓-王姓

王姓在《百家姓》中虽然排名第八,但根据近年来的统计数据和实际人口分布,王姓已成为中国第一大姓。以下是对王姓作为“百家姓之首”的详细解析: 一、人口数量与分布 人口数量:截至当前时间(2024年)&#x…

Jmeter 配置元件-计数器时间变量

计数器 在 JMeter 中,计数器是一个非常有用的配置元件,可以帮助你在每次请求时生成递增的数字。 在线程组下新增计数器 配置计数器 开始值(Starting value):给定计数器的起始值、初始值,第一次迭代时&…

我们离生成式 AI 应用全面爆发还有多远?2024 全球产品经理大会透露了这些关键信号

GenAI 应用爆发何时到来、生成式 AI 应用到底该怎么做……大模型浪潮已经有将近两年的时间,去年狂卷模型,今年业内则一致认为是应用落地元年,但其间困惑诸多,产品人与创业者们该何去何从,答案尽在 2024 全球产品经理大…

Linux 常用命令(待更新)

1、pwd命令 2、cd命令 3、ls命令 4、locate命令 5、clear命令 6、cat命令 7、head命令 8、tail命令 9、grep命令 10、chmod命令 11、cp命令 12、mv命令 13、mkdir命令 14、rm命令 15、文件压缩和有关归档的命令 16、文件系统的命令 17、与系统管理相关的命令 …

七种修复错误:由于找不到msvcr110.dll 无法继续执行的方法

当你在运行某些程序时遇到“找不到msvcr110.dll”的错误提示,这通常意味着你的系统缺少了Microsoft Visual C 2012 Redistributable包中的一个重要文件。这个DLL文件是Microsoft Visual C Redistributable的一部分,用于支持许多使用Visual C编写的软件和…

Linux:文件描述符详解

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 Linux中的所有进程,都拥有自己的文件描述符(File Descriptor, FD),它是操作系统在管理进程和文件时的一种抽象概念。每个文件描述符由一个非负整…

链接器查找其他动态库的过程

export LD_DEBUGall 2./your_program 这将输出所有的调试信息,包括搜索路径、库的加载、符号解析等详细信息。 关闭用unset LD_DEBUG 常用的 LD_DEBUG 选项包括: all: 输出所有调试信息。paths: 显示搜索路径信息。files: 显示文件打开和关闭的信息。…

使用天地图实现只展示某个市的功能

可参考 天地图部分功能hooks封装useTdtMap.js 和 处理geoJson格式数据并能回显至天地图上 下面实现效果类似于百度地图-展示部分区域 功能图 部分代码 const initLoad () > {mapInit().then((res) > {map.value res;var layers map.value.getLayers();layers.forEac…

CSS04-Chrome调试工具

Chrome 浏览器提供了一个非常好用的调试工具,可以用来调试我们的 HTML结构和 CSS 样式。

成功使用DDNS动态域名访问我的群晖NAS(TP-link路由器)

当NAS设备部署在动态IP环境中(如家庭或小型办公室宽带),远程访问常常受到IP地址频繁变动的困扰。为了解决这一问题,结合神卓互联NAS公网助手提供的DDNS(动态域名服务)功能,我们可以轻松实现通过…

keil软件编写第一个c语言单片机程序并下载到单片机点亮一个发光二极管

Project-->new project-->选择文件夹-->输入工程名如:lession_1-->选择单片机芯片类型(Atml的89c52)-->newfile -->保存输入C语言文件名lession_1.c-->在左侧source Group 1右键--->选择add files to group “Source…

FPGA实现频率、幅度、相位可调的DDS以及DDS Compiler IP核的使用验证

文章目录 一、DDS介绍二、DDS原理2.1 频率计算2.2 相位改变2.3 波形切换 三、Matlab生成波形文件四、FPGA实现DDS4.1 Verilog代码4.2 仿真验证4.2.1 改变频率4.2.2 切换波形4.2.3 相位调节4.2.4 幅度调节 五、Xilinx DDS Compiler的使用5.1 功能框图5.1.1 相位累加器5.1.2 SIN/…

Linux系统接口--信号量、互斥锁、原子操作和自旋锁的区别

1、基本概念 1.1 信号量(Semaphore) (1)定义 信号量是一种计数器,用于控制对共享资源的访问,允许多个线程同时访问一定数量的资源。 (2)特点 计数型信号量: 信号量有…

FSMC寄存器方式初始化及LCD函数

环境 芯片:STM32F103ZET6 库:stm32f10x.h 原理图 代码 Driver.FSMC.h #ifndef __DRIVER_FSMC #define __DRIVER_FSMC #include "stm32f10x.h"void Driver_FSMC_Init(void);#endifDriver.FSMC.c #include "Driver_FSMC.h"/*** 配置FSMC(Flexi…

最新免费商用无版权素材(免费图库 抠图 PNG 插画素材)

今天我要给大家揭秘几个私藏的宝藏网站——那些免费、商用无版权的素材资源站!🎉 这些站点简直好用到爆炸💥,每次需要找素材,它们总能秒速响应,让我们的工作效率直线飙升!🚀 这里不…

32岁前端干了8年,是继续做前端开发,还是转其它工作_ui设计师转开发

前端发展有瓶颈,变来变去都是那一套,只是换了框架换了环境。换了框架后又得去学习,虽然很快上手,但是那些刚毕业的也很快上手了,入门门槛越来越低,想转行或继续卷,该如何破圈? 这是一位网友的自…

nmap 命令:网络扫描

一、命令简介 ​nmap​(Network Mapper)是一个开放源代码的网络探测和安全审核的工具。它最初由Fyodor Vaskovich开发,用于快速地扫描大型网络,尽管它同样适用于单个主机。 ​nmap​的功能包括: 发现主机上的开放端…

基于 BERT 的自定义中文命名实体识别实现

基于 BERT 的自定义中文命名实体识别实现 在自然语言处理中,命名实体识别(Named Entity Recognition,NER)是一项重要的任务,旨在识别文本中的特定实体,如人名、地名、组织机构名等。本文将介绍如何使用 BERT 模型实现自定义中文命名实体识别,并提供详细的代码分析和解读…

SpringBoot3自动配置(持续更新)

博客主页:音符犹如代码系列专栏:JavaWeb关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ 自动配置 在SpringBoot中,自动配置是一个核心的特性,…

(done) 声音信号处理基础知识(1) (course overview)

来源:https://www.youtube.com/watch?viCwMQJnKk2c 声学处理应用场景如下 这个系列的内容包括如下: 作者的 slack 频道 油管主的 github repo: https://github.com/musikalkemist/AudioSignalProcessingForML