Git系列--3.分支管理

目录

一、理解分支

        1.1图示

        1.2 打印仓库下有哪些分支

        1.3创建分支

        1.4HEAD与切换分支

        1.5合并分支

        1.6流程图理解

二、删除分支

三、合并分支冲突

        3.1.问题导入

        3.2.解决

        3.3合并图示

四、合并模式

       4.1合并​编辑

        4.2变基

五、bug分支

        5.1背景建立

        5.2解决步骤

                5.2.1保存dev2工作区内容

                 5.2.2建立bug分支,修改bug并提交与合并到主分支

                 5.2.3新功能研发,合并到研发分支测试

                 5.2.4合并到主分支

                 5.2.5流程图示

六、强制删除分支


一、理解分支

        1.1图示

             我们可以利用分支在同一时间进行多人并行工作,最后合并到主分支上进行最终管理 

         1.2 打印仓库下有哪些分支

git branch

        1.3创建分支

git branch branchname

        1.4HEAD与切换分支

        前文提到HEAD指向分支,这里明确HEAD指向主分支(带*的)

//切换HEAD所指的的主分支
git checkout branchname

        1.5合并分支

//将branchname合并到当前分支
git merge brancname

        1.6流程图理解

二、删除分支

        不能在当前分支删除自己

git branch -d brancename

三、合并分支冲突

        3.1.问题导入

                发生冲突


       

        3.2.解决

        手动解决并进行一次提交操作

          冲突文件内容,手动修改后提交

        3.3合并图示

四、合并模式

       4.1合并

git checkout main         # 切换到目标分支
git merge feature-branch  # 合并源分支

        4.2变基

  

git checkout feature-branch  # 切换到源分支
git rebase main             # 变基到目标分支

五、bug分支

        假如我们现在正在 dev2 分⽀上进⾏开发,开发到⼀半,突然发现 master 分⽀上⾯有 bug,需要解决。在Git中,每个 bug 都可以通过⼀个新的临时分⽀来修复,修复后,合并分⽀,然后将临时分⽀删除。

        5.1背景建立

                master出现bug--abcde缺少f使程序崩溃
        
dev2正在研究新功能(未提交)

        5.2解决步骤

                5.2.1保存dev2工作区内容

                        由于我们要从master建立bug分支进行修改,所以我们要保存dev2工作区内容,防止被新分支修改(dev2上内容为临时内容会被master看见)

//在dev2分支上:
git stash

                   5.2.2建立bug分支,修改bug并提交与合并到主分支
git checkout master
git checkout -b fix_bug
git add .
git commit -m ""
git cheackout master
//--no-ff No Fast Forward模式
git merge --no-ff branchname
      
                        5.2.3新功能研发,合并到研发分支测试
git stash pop
//恢复工作区内容
git merge --no-ff master
//合并到研发分支测试
git checkout master
git merge --no-ff dev2

                        5.2.4合并到主分支

        

                      5.2.5流程图示

六、强制删除分支

        如果我们今天正在某个 feature 分⽀上开发了⼀半(已被git管理),被产品经理突然叫停,说是要停⽌新功 能的开发。虽然⽩⼲了,但是这个 feature 分⽀还是必须就地销毁,留着⽆⽤了。这时使⽤传统 的 git branch -d 命令删除分⽀的⽅法是不⾏的。
//使用
git branch -D branchname

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

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

相关文章

Vue.js TDD开发深度指南:工具链配置与精细化测试策略

“TDD不是测试优先的开发,而是设计优先的开发。” —— Robert C. Martin 引言 在Vue.js项目中实施测试驱动开发(TDD)是构建健壮应用的关键路径。但许多开发者在实践中常遇到: 工具链配置复杂导致放弃不同类型组件测试策略混淆测…

基于物联网的智能家居控制系统设计与实现

标题:基于物联网的智能家居控制系统设计与实现内容:1.摘要 随着物联网技术的飞速发展,智能家居逐渐成为人们关注的焦点。本文旨在设计并实现一个基于物联网的智能家居控制系统,以提高家居的智能化水平和用户的生活便利性。通过采用先进的传感器技术、通信…

Vue 中使用 Cesium 实现可拖拽点标记及坐标实时显示功能

在 Cesium 地图开发中,实现点标记的拖拽交互并实时显示坐标信息是一个常见的需求。本文将详细介绍如何在 Vue 框架中使用 Cesium 的 Primitive 方式创建点标记,并实现拖拽功能及坐标提示框跟随效果。先看效果图功能实现概述我们将实现的功能包括&#xf…

HTML 插件:构建网页的强大工具

HTML 插件:构建网页的强大工具 引言 HTML 插件是网页设计中不可或缺的一部分,它们为网页增添了丰富的交互性和动态效果。本文将深入探讨 HTML 插件的概念、类型、应用及其在网页开发中的重要性。 什么是 HTML 插件? HTML 插件,也称为 HTML 组件或 HTML 控件,是指嵌入到…

NeRF、3DGS、2DGS下三维重建相关方法介绍及以及在实景三维领域的最新实践

一、引言 在计算机视觉与图形学领域,三维重建技术正经历从传统几何建模向智能化神经表征的范式转变。近年来,随着深度学习算法的迭代、传感器技术的进步及计算硬件的升级,以神经辐射场(NeRF)和高斯泼溅(2D…

rt thread studio 和 KEIL对于使用rt thread 的中间件和组件,哪个更方便

下面我从中间件/组件集成和开发体验两个角度,详细对比 RT-Thread Studio 和 Keil MDK 的便利性:1. 中间件和组件集成 RT-Thread Studio 集成RT-Thread生态:内置RT-Thread的包管理器(RT-Thread Package Manager)&#x…

Spring Boot 项目开发实战:入门应用部分原理示例讲解

前言Spring Boot 作为当前 Java 开发领域最流行的框架之一,以其 "约定优于配置" 的理念极大简化了企业级应用的开发流程。本文将基于《Spring Boot 项目开发教程(慕课版)》中的资产管理系统项目,深入解析 Spring Boot 的…

ByteBrain x 清华 VLDB25|时序多模态大语言模型 ChatTS

资料来源:火山引擎-开发者社区 近年来,多模态大语言模型(MLLM)发展迅速,并在图像、视频、音频等领域取得了突破性成果。然而,相较于这些研究较为成熟的模态,时间序列这一类型的数据与大模型结合…

WPF学习笔记(25)MVVM框架与项目实例

MVVM框架与项目实例一、MVVM框架1. 概述2. 核心组件与优势一、MVVM项目1.普通项目2. MVVM架构3. MVVM项目实例1. 项目准备2. LoginViewModel与Login2. MainWindowViewModel4. MVVM项目优化1. BaseViewModel2. RealyCommand3. 效果展示总结一、MVVM框架 1. 概述 官方文档&…

MySQL实操

## 基于MySQL#先启动MySQL服务#第一次登录[rootlocalhost ~]# mysql -uroot -P3306#密码登录[rootlocalhost ~]# mysql -uroot -pEnter password: Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 9Server version: 8.0.41 Source dist…

ez_rust_writeup

一道简单的[[rust逆向]] #rust逆向 #位运算 题目信息 文件名:ezrust.exe 题目附件:https://wwfj.lanzoul.com/iczMR30k5j4h 密码:bueq 题目分析 1. 初步分析 这是一道Rust编写的逆向题目。通过IDA分析可以看到,这是一个典型的flag验证程序。 …

【QT】-隐式转换 explicit用法

通俗易懂的解释:隐式转换 vs 显式转换 什么是隐式转换? 隐式转换就是编译器偷偷帮你做的类型转换,你甚至都没意识到它发生了。 例子: cpp 运行 double x = 5; // 隐式:int → double(5 变成 5.0) int y = x * 2.5; // 隐式:double → int(截断小数部分) 构造函数的隐…

Django核心知识点详解:JSON、AJAX、Cookie、Session与用户认证

1. JSON数据格式详解1.1 什么是JSON?JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,具有以下特点:独立于语言,几乎所有编程语言都支持易于人阅读和编写易于机器解析和生成基于文本&#xff…

[特殊字符] Python 实战 | 批量统计中文文档词频并导出 Excel

本文展示如何用 Python 脚本: 批量读取文件夹中的多篇中文文档; 用 jieba 分词并统计词频(过滤停用词与单字符); 将各文档词频输出为对应 Excel 文件; 是文本分析、内容审查、报告编写中的实用技巧。 &…

共享打印机(详细操作+常见问题:需输入用户名密码、无法连接等)

文章目录一、设置打印机共享的准备工作二、Windows系统下打印机共享设置1. 启用主机打印机共享2. 客户端添加共享打印机三、我所遇到的问题及解决方法客户机遇到输入用户名、密码错误代码 0x0000011b一、错误代码 0x0000011b 的含义二、解决方法添加打印机没成功其他问题此次打…

在 Windows 系统上配置 [go-zero](https://go-zero.dev) 开发环境教程

💻 在 Windows 系统上配置 go-zero 开发环境教程 本教程将详细介绍如何在 Windows 系统上配置 go-zero 微服务框架的开发环境,包括依赖安装、路径配置、常见问题等。 🧱 一、前置环境安装 1. 安装 Go 下载地址:https://go.dev/…

开源=白嫖?

国内有一个非常浓重的思想,开源,开源就是免费,就是白嫖,就是不花钱,白给。那么什么是开源?“源代码”是软件中大多数计算机用户从未见过的部分;它是计算机程序员可以操纵的代码,以改变一个软件(…

2048-控制台版本

2048控制台版 文章目录2048控制台版实现效果:在这里插入图片描述库函数使用:初始化变量功能函数实现:状态判断函数int Judge();数字生成函数 bool CtreateNumber()打印游戏界面 void…

提取出Wallpaper Engine壁纸的mpkg类静态壁纸

github 地址 https://github.com/notscuffed/repkg先下载软件2853…26目录这样获取有的直接mp4格式,就不能用这方法准备好后 cmd 进入repkg目录 执行 repkg extract ./294...333/scene.pkg

AI健康小屋“15分钟服务圈”:如何重构社区健康生态?

AI健康小屋作为“15分钟服务圈”的核心载体,通过技术赋能与场景重构,正推动社区健康生态从被动治疗向主动预防、从单一服务向全周期管理转型。那我们应该如何重构社区健康生态呢?服务模式创新1.全时段覆盖AI健康小屋通过分时段服务满足不同群…