Git 分支操作全解析:创建、切换、合并、删除及冲突解决

        “ 在现代软件开发中,高效的版本控制是确保项目成功的关键。Git 提供了强大的分支管理功能,使得开发者能够独立地进行功能开发、修复 bug 和进行紧急修补。本文将深入探讨 Git 分支的基本操作,包括创建、切换、合并和删除分支,同时重点关注如何解决常见的冲突问题。掌握这些技巧不仅能提升开发效率,还能优化团队协作。让我们一起来揭开 Git 分支管理的神秘面纱,提升项目的管理水平。

01分支简介 

        管理代码的时候,在集中式管理(比如SVN)中会创建Trunk、Branches、Tag等一些目录,分别放置开发代码、代码分支以及代码的里程碑。那么在 Git 中也使用分支和tag来管理代码。分支就是就是一个代码的副本,可以基于分支进行独立开发。比如我们创建 Bug 分支或者 Feature 分支,等开发好了再合并到主干上。使用 Git 可以非常方便灵活地管理分支和基于分支工作:

git branch   # 查看分支
git branch develop  # 创建develop分支
git checkout –b feature/FT-123456  # 创建FT-123456的一个feature分支
git checkout develop   # 切换分支
git merge feature/FT-123456   # 合并分支
git branch –d feature/FT-123456   # 删除FT-123456的feature分支
git push –u origin hotfix/ISSUE-345678    # 推送分支

版本管理的标准流程:

  • Master :稳定压倒一切,禁止尚 review 和测试过的代码提交到这个分支上,Master上的代码是可以随时部署到线上生产环境的。

  • Develop :开发分支,我们的持续集成工作在这里,code review过的代码合入到这里,我们以下要讲的BUG fix和feature开发都可以基于develop分支拉取,修改完之后合入到develop分支。

  • Feature :功能开发和change request的分支,也即我们每一个feature都可以从devlop上拉取一个分支,开发、review和测试完之后合入develop分支。

  • Hotfix :紧急修改的分支,在master发布到线上出现某个问题的时候,算作一个紧急布丁。从master分支上拉取代码,修改完之后合入develop和master分支。

  • Release :预发布分支,比如0.1、0.2、1.12版本,我们一般说的系统测试就是基于这些分支做的,如果出现bug,则可以基于该release分支拉取一个临时bug分支。

  • Bug :bug fix的分支,当我们定位、解决后合入develop和Release分支,然后让测试人员回归测试,回归测试后由close这个bug。

02查看分支 

        首先要知道怎么去查看分支,使用git branch命令,这个命令只打印本地仓库的分支;如果想把远端的分支也查看一番,可以使用git branch -a命令。其中其星号*表示当前在哪个分支。示例:

 

fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$ git branch
* master
fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$ git branch -a
* masterremotes/origin/HEAD -> origin/masterremotes/origin/master
fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$

03创建、切换分支

创建分支有两种方式:

git branch 分支名
git checkout -b 分支名

它们的不同:

  • git branch 分支名虽然创建了分支,但不会自动切换到新建的分支;而且是在本地创建的分支,远端没有这个分支。

  • git checkout -b也会创建分支,而且会自动切换到新的分支上。

  • 切换分支也有两种方式:

    git checkout 分支名
    git switch 分支名
    

    git check命令的功能很多,除了切换分支,还可以做版本回退等操作,因此,后来 Git 又增加了一个git switch命令。

    git checkout -b可以理解为两个命令的结合,即 创建分支 + 切换分支两个操作合成一个命令。

    04合并分支 (重点)

合并分支有两个命令:

  • git merge

  • git rebase,不推荐使用。git rebase不仅可以合并提交,还可以合并分支。

合并分支的主要作用:通常,在实际项目开发过程中,会有多个分支,而且都是基于某个主分支进行开发。最终,所有的分支实现的功能都要合并到主分支,所有人都可以看到项目的修改。我们要把自己分支的修改应用到主分支,就需要合并分支。

 

git merge合并 Git 分支的步骤:

  1. 切换到目标分支:这是你希望将更改合并到的分支。例如,如果你想将 feature-branch 合并到 main,需要首先切换到 main 分支,拉取该分支的最新代码。

    git checkout main
    git pull
    
  2. 合并分支:使用 git merge 命令将另一个分支合并到当前分支。例如,将 feature-branch 合并到 main:

    git merge feature-branch
    
  3. 处理冲突(如果有):如果存在冲突,Git 会提示你解决冲突。你需要手动编辑冲突的文件,然后添加更改并完成合并。

# 编辑冲突文件
vim 冲突的文件
# 解决冲突后,添加已解决的文件
git add <file-with-conflict># 完成合并
git commit . -i -m "merge fix conflicts."

冲突文件示例:

  1. 测试代码并推送更改(如果需要):将合并后的更改推送到远程仓库。

    git push origin main
    

git rebase合并分支(不推荐使用)
使用 git rebase 进行分支合并的步骤如下:

  1. 切换到需要更新的分支:假设要将 feature-branch 的更改应用到 main 分支上,首先需要切换到 feature-branch。

    git checkout feature-branch
    
  2. 执行 rebase 操作:将 feature-branch 的更改应用到 main 分支上。

    git rebase main
    

    这会将 feature-branch 上的提交“移到” main 分支的顶部。feature-branch 上的更改将会被逐个应用到 main 上的最新提交之后。

  3. 解决冲突(如果有):如果在 rebase 过程中出现冲突,Git 会提示解决冲突。解决冲突后,继续 rebase 操作。注意,git rebase解决完冲突后并不会增加一次提交。

 

# 编辑冲突文件
vim 冲突的文件
# 解决冲突后,添加已解决的文件
git add <file-with-conflict># 继续 rebase
git rebase --continue

  1. 推送更改(如果需要):由于 rebase 操作会改变提交历史,如果已经将 feature-branch 推送到远程仓库,需要强制推送更新。

    git push --force origin feature-branch
    

    注意:强制推送会覆盖远程仓库中的 feature-branch,在共享仓库中使用时请小心。

不推荐使用git rebase的原因:虽然git rebase让提交记录非常整洁,它整体上比git merge上一个提交记录,但是它会让人造成混淆(时间线错乱),无法辨别真正的版本依赖关系。

git merge更加符合实际开发的时间线。

 什么时候使用git rebase ?
依据是:是否有其他人依赖我当前rebase的这个分支。如果有依赖,则应当采用git merge进行合并,否则可以 使用git rebase 命令。因为git rebase会改变提交日志(即 commit id),如果有人依赖我的分支,就可能出现异常。

git rebase原理:从两个分支的共同祖先开始提取当前分支上的修改,提取的提交应用到目标分支的最新提交的后面,将当前分支指向目标分支的最新提交,可能引发其他人基底发生改变。

05删除分支 

删除本地分支:

  1. 切换到其他分支:在删除分支之前,确保不在要删除的分支上。例如,如果要删除 feature-branch,可以切换到 main 或其他分支。

    git checkout main
    
  2. 删除本地分支:使用 -d 选项删除本地分支,如果分支上有未合并的更改,Git 会警告你。

    git branch -d feature-branch
    

    如果你确定要删除分支,即使它有未合并的更改,可以使用 -D(强制删除):

    git branch -D feature-branch
    

删除远程分支:使用 git push 命令并指定 --delete 选项来删除远程分支。例如,删除远程 feature-branch

git push origin --delete feature-branch
# or
git push origin -d feature-branch

06解决冲突  

        冲突产生原因:不同分支修改了同一文件的同一行或者相邻行。
        解决原则:不要影响其他人提交的功能,也不能破坏自己提交的功能。也可以跟其他人协商解决。
建议:提交前先pull更新最新代码。

 

git mergegit rebase解决冲突的不同:

  • git merge先解决冲突文件,然后使用git add,最后git commit . -i -m "....",完成。

  • git rebase先解决冲突文件,然后使用git add.标记解决,最后git rebase --continue,完成。

 

07总结 

        在软件开发过程中,Git 的分支管理是实现高效协作和版本控制的核心工具。通过本文的介绍,深入探讨了 Git 分支的创建、切换、合并、删除及冲突解决等操作,帮助开发者掌握了以下几点关键内容:

  1. 分支管理的基本概念:Git 的分支机制允许我们在独立的环境中进行开发和测试,确保主分支的稳定性。理解分支的作用(如 FeatureBugHotfix 和 Release)对有效管理项目至关重要。

  2. 创建和切换分支:使用 git branch 和 git checkout -b 创建和切换分支,使得开发者能够灵活地在不同功能或修复任务之间切换,提高了开发的灵活性和组织性。

  3. 合并分支的技巧:合并分支是将开发成果整合到主干的关键步骤。通过 git merge 和 git rebase,可以将功能分支的更改引入到主分支中。选择合适的合并策略对于避免冲突和保持提交历史的清晰至关重要。

  4. 处理冲突:冲突是分支管理中常见的问题。通过 git merge 和 git rebase 提供的工具和方法,可以有效地解决冲突,确保代码库的稳定性。理解冲突产生的原因和解决原则能够帮助团队更高效地协作。

  5. 删除分支:分支的删除操作(包括本地和远程)有助于保持项目的整洁。了解如何安全地删除不再需要的分支,可以避免混乱和不必要的分支堆积。

 

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

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

相关文章

Linux基础 - yum、rzsz、vim 使用与配置、gcc/g++的详细解说

目录 一、Linux 软件包管理器 yum A.什么是软件包&#xff1f; B.关于rzsz&#xff0c;yum的配置 1.安装 sz&#xff0c;rz 命令&#xff1a; a.执行命令sz可将linux中的文件传输到Windows中 b.执行rz命令可将Windows中的文件传输到linux 2.scp XXX.tgz 用户名另一台lin…

免费高画质提取PPT/Word/Excel中的图片工具

下载地址&#xff1a;https://pan.quark.cn/s/134ccc35b8a2 软件简介&#xff1a; 好不容易搞到一个几十上百MB的ppt&#xff0c;想导出里面的图片进行二次加工&#xff0c;却被ppt超低画质的图片另存为功能劝退&#xff0c;明知里面全是高清图片&#xff0c;走时却是两手空空…

1系-8系铝合金材料的成分特性及应用详解

1系-8系铝合金材料的成分特性及应用详解 铝合金概述 铝合金的定义铝合金是一种以铝为基体&#xff0c;通过添加一定量的其他合金化元素&#xff08;如铜、锰、硅、镁、锌等&#xff09;形成的合金材料。由于合金元素的加入&#xff0c;铝合金在保持铝的轻质、良好导电导热性等基…

langchain入门系列之六 使用langchain构建PDF解析助手

本文将介绍如何使用langchain构建一个pdf解析助手&#xff0c;在此文中你将学习到langchain如何与web应用(fastapi)相结合&#xff0c;向量持久化等知识&#xff0c;话不多说&#xff0c;现在开始。 安装环境 pip install fastapi pip install python-dotenv pip install uv…

漫步者这款耳机怎么样吗?南卡、漫步者、Cleer公认畅销款式测评!

目前市场上开放式耳机品牌众多&#xff0c;选择时需要充分了解&#xff0c;但即便如此&#xff0c;也难以完全避免购买到质量不佳的产品。作为一位专注于数码产品测评的博主&#xff0c;我对开放式耳机有深入的研究。最近&#xff0c;我收到了许多关于漫步者、南卡、Cleer等品牌…

Flutter-自适用高度PageView

需求 在 Flutter 中&#xff0c;PageView 是一个非常常用的组件&#xff0c;能够实现多个页面的滑动切换。然而&#xff0c;默认的 PageView 高度是固定的&#xff0c;这在展示不同高度的页面时&#xff0c;可能会导致不必要的空白或内容裁剪问题。为了使 PageView 能够根据每…

OpenMax算法详解:深度学习中的高效开集识别技术

OpenMax算法详解&#xff1a;深度学习中的高效开集识别技术 在深度学习领域&#xff0c;模型的识别能力往往受限于其训练数据集的范畴。传统的分类模型&#xff0c;如卷积神经网络&#xff08;CNN&#xff09;或循环神经网络&#xff08;RNN&#xff09;&#xff0c;通常被设计…

第八节:Nodify 编辑器属性

引言 经过前几章的学习&#xff0c;你已经对Nodify框架有了初步的编程思路。当然只局限于这些还完全不够&#xff0c;本章节将阐述各个结构组件的一些常用属性&#xff0c;以便在日后的开发过程中更得心应手。 1、编辑器 平移 简介属性默认值平移功能 控制DisablePanningfals…

100128-批量获取视频音频时长添加到文件名中支持子孙文件夹下操作-UI

程序功使用环境▶适用的系统环境说明&#xff1a;win7以上64位win系统注意&#xff1a;win32位系统/mac系统需要额外定制▶使用期限&#xff1a;无需注册、不绑电脑、无时间限制▶如何安装&#xff1a;不需要安装程序功能说明▶子文件夹穿透&#xff1a;支持▶支持的文件格式&a…

MySQL集群技术详解

目录 一、MySQL在服务器中的部署方法 1.1 编译安装MySQL 1.2 部署MySQL 二、MySQL主从复制 2.1 配置master 2.2 配置slave 2.3 添加slave2 测试&#xff1a; 2.4 延迟复制 2.5 慢查询日志 2.6 MySQL的并行复制 2.7 MySQL主从复制原理剖析 2.8 架构缺陷 三、MySQL…

学习笔记——IP组播——IP组播基本概述

二、IP组播基本概述 IP组播技术有效地解决了单播和广播在点到多点应用中的问题。组播源只发送一份数据&#xff0c;数据在网络节点间被复制、分发&#xff08;PIM&#xff09;&#xff0c;且只发送给需要该信息的接收者。 1、前言 网络中存在各种各样的业务&#xff0c;从流…

EasyCVR视频汇聚平台革新播放体验:WebRTC协议赋能H.265视频流畅传输

随着科技的飞速发展和网络技术的不断革新&#xff0c;视频监控已经广泛应用于社会各个领域&#xff0c;成为现代安全管理的重要组成部分。在视频监控领域&#xff0c;视频编码技术的选择尤为重要&#xff0c;它不仅关系到视频的质量&#xff0c;还直接影响到视频的传输效率和兼…

企业参与制定行业标准的主要途径有哪些?需要具备哪些条件?

在当今竞争激烈的商业环境中&#xff0c;参与制定行业标准已成为企业提升竞争力、塑造行业地位的重要战略举措。然而&#xff0c;并非所有企业都有能力和资格参与这一重要的活动。要想在行业标准制定的舞台上发挥积极作用&#xff0c;企业需要具备一系列关键条件。 企业参与制…

mapstruct和lombok同时使用时,转换实体类时数据丢失

全局搜一下maps&#xff0c;找到你进行转换的方法 可以看到新建了TswCaseInfoPlus后直接返回了&#xff0c;说明TswCaseInfoPlus没有set方法&#xff0c;或者说编译后lombok没生效 在pom文件中&#xff0c;编译打包插件中将lombok&#xff0c;mapstruct&#xff0c;lombok-map…

3ds Max - 导出顶点色模型

很久之前的笔记&#xff0c;整理归档&#xff1b; 在3ds Max中&#xff0c;给模型添加VetexPaint修改器后&#xff0c;可以给模型&#xff08;顶点色通道R\G\B默认值为255\255\255&#xff09;刷不同颜色的顶点色&#xff08;默认为黑色&#xff0c;即让RGB通道都为0&#xff0…

PY信号和槽

知不足而奋进 望远山而前行 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 系列文章目录前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 在使用PyQt进行图形用户界面&#xff08;GU…

jenkins发送html邮件配置步骤与注意事项?

jenkins发送html邮件如何实现&#xff1f;Jenkins的配置方法&#xff1f; 通过jenkins发送html邮件&#xff0c;开发团队可以及时获取构建状态的详细报告&#xff0c;从而快速响应问题&#xff0c;提高工作效率。AokSend将详细介绍jenkins发送html邮件的配置步骤与注意事项&am…

【实现100个unity特效之28】皮毛shader着色器 实现可以用动的毛茸茸毛绒绒效果

效果 文章目录 效果一、内置渲染管线下载支持几只着色器Basic 基本Attributes 属性Force 力Rim Color 轮辋颜色 二、URP下载几只毛发着色器实现的示例Shell 壳Fin 翅片Fur Polygon 毛发多边形Compare 比较Move 移动 完结 一、内置渲染管线 缺点是仅支持内置渲染管线。且无法毛…

各个版本jdk新特性

jdk8新特性 方法引用&#xff1a;方法引用允许直接通过方法的名称来引用已经存在的方法&#xff0c;简化了函数式接口的实现。默认方法&#xff08;Default Methods&#xff09;&#xff1a;默认方法允许在接口中定义具有默认实现的方法&#xff0c;以便接口的实现类可以继承该…

Linux基础知识(一、什么是Linux)

一、Linux之父——林纳斯本纳第克特托瓦兹&#xff08;Linus Benedict Torvalds&#xff09; Linux操作系统最初是在1991年10月份由芬兰赫尔辛基大学的在校生Linus Torvalds所发布,最初被发布的LINUX0.02版本因其高质量的代码与开放源代码&#xff0c;迅速引起了一大批黑客的加…