Git 分支管理详解

news2025/7/6 22:26:41

1.前言 

我们先来说一个简单的案例吧,你们团队中有多个人再开发一下项目,一同事再开发一个新的功能,需要一周时间完成,他写了其中的30%还没有写完,如果他提 交了这个版本,那么团队中的其它人就不能继续开发了。但是等到他全部写完再全部提交,大家又看不到他的开发进度,也不能继续干活,这如何是好呢? 

对于上面的这个问题,我们就可以用分支管理的办法来解决,一同事开发新功能他可以创建一个属于他自己的分支,其它同事暂时看不到,继续在开发分支(一般都 有多个分支)上干活,他在自己的分支上干活,等他全部开发完成,再一次性的合并到开发分支上,这样我们既可知道他的开发进度,又不影响大家干活,是不是很 方便呢? 

分支本质上其实就是一个指向某次提交的可变指针。Git 的默认分支名字为 master 。而我们是怎么知道当前处于哪个分支当中呢?答案就是在于 HEAD 这个十分特殊的指针,它专门用于指向于本地分支中的当前分支。我们可以简单理解为:commit <- branch <- HEAD (注,本来我们详细说一下HEAD的,这个东西真不好说,goole了一下也没几个大神说这个。下面我就通过讲解帮助大家理解,简单的说HEAD就 是指向于本地分支中的当前分支,如下图:) 下面我们来创建分支。 

2.创建分支 

当我们需要调试某个Bug或者尝试添加或修改程序中的某个模块,而又不能影响主分支的开发时。就可以通过创建分支来满足需求。创建分支相当于是创建一个新的分支指针指向当前所在的提交。我们在Commit3上创建dev分支: 

如下图所示,dev分支指向Commit3。 

从上图可知,虽然我们创建了一个新分支,但是 HEAD 仍然指向 master 。如果希望在创建分支的同时切换到新分支上,我们可以通过以下命令实现: 

git checkout命令加上-b参数表示创建并切换分支上。 

3.切换分支 

切换当前分支我们可以用以下命令实现: 

git branch -a 命令可以查看所有分支,现在我们HEAD指针便指向dev分支,大家可以在上图中看到dev分支上有个*号。 

下面我们修改一下readme.txt中的内容,并在dev分支上提交一下。如下图: 

用流程图演示上述过程如下: 

现在我们在dev分支上完成工作,现在到master分支上。如下图: 

流程图表示如下: 

切换回master分支后,再查看一个readme.txt文件,如下图: 

大家可以看到我们刚才增加的一行内容不见了,嘿嘿。因为那个提交是在dev分支上,而master分支没有变化。好了,下面我们来演示一下合并分支。 

4.合并分支(快速合并) 

现在,我们把dev分支的工作成果合并到master分支上,如下图: 

git merge 命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。如下图: 

大家注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度 非常快。当然,也不是每次合并都能Fast-forward,我们后面会将其他方式的合并。合并完成后,就可以放心地删除dev分支了。 

5.删除分支 

下面我们来演示一下删除分支,如下图: 

大家在实际操作中可以发现在我们创建、合并、删除分支的速度非常快吧,这和直接在master分支上工作效果是一样的,但过程更安全,更可靠。下面我们来简单的总结一下: 

  • 查看分支 git branch -a 
  • 创建分支 git branch name 
  • 切换分支 git checkout name 
  • 创建并切换 git checkout -b name 
  • 合并某分支到当前分支 git merge name 
  • 删除分支 git branch -d name 

6.分支合并冲突 

下面我们来演示一下不同分支修改同一个文件产生冲突问题,下面我们来创建一个新的分支,继续开发新功能: 

现在我们将分支切换到master分支上修改readme.txt内容并提交,如下图: 

这种情况下,Git无法执行“快速合并”,只能试图把各自的修改合并起来,但这种合并就可能会有冲突,如下图: 

果然冲突了,Git告诉我们readme.txt文件存在冲突,必须手动解决冲突后再提交。下面我们用git status查看一下状态: 

下面我们来查看一下readme.txt中的内容,如下图: 

Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容,让我们选择要保留的内容,下面我们修改一下readme.txt,再次提交。如下图: 

好了,到这我们的分支合并冲突就讲解完成了,下面我们来删除分支。如下图: 

最后,我们可以用 git log --graph --pretty=oneline --abbrev-commit 命令,查看一下分支合并。 

7.合并分支(普通合并) 

分支合并分为快速合并与普通合并两种模式,普通合并,合并后的历史有分支记录,能看出来曾经做过合并,而快速合并就看不出来曾经做过合并。下面我们来演示一下普通合并, 

大家可以看到我们这次合并用的普通模式合并,--no-ff参数表示禁用快速合并。下面我们用git log命令查看一下合并历史: 

注,合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支记录,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。如下图: 

1).快速合并

2).普通合并

8.分支管理策略 

下面我们来说一下一般企业中开发一个项目的分支策略: 

  • 主分支 master 
  • 开发分支 develop 
  • 功能分支 feature 
  • 预发布分支  release 
  • bug 分支 fixbug 
  • 其它分支 other 

1).主分支 master

代码库应该有一个、且仅有一个主分支。所有提供给用户使用的正式版本,都在这个主分支上发布。 

Git主分支的名字,默认叫做Master。它是自动建立的,版本库初始化以后,默认就是在主分支在进行开发。 

2).开发分支 develop

主分支只用来分布重大版本,日常开发应该在另一条分支上完成。我们把开发用的分支,叫做Develop。 

这个分支可以用来生成代码的最新代码版本。如果想正式对外发布,就在Master分支上,对Develop分支进行"合并"(merge)。 

3).功能分支 feature

功能分支,它是为了开发某种特定功能,从Develop分支上面分出来的。开发完成后,要再并入Develop。 

功能分支的名字,可以采用feature-*的形式命名。 

4).预发布分支  release

预发布分支,它是指发布正式版本之前(即合并到Master分支之前),我们可能需要有一个预发布的版本进行测试。预发布分支是从Develop分支上面 分出来的,预发布结束以后,必须合并进Develop和Master分支。它的命名,可以采用release-*的形式。 

5).bug 分支 fixbug

bug分支。软件正式发布以后,难免会出现bug。这时就需要创建一个分支,进行bug修补。修补bug分支是从Master分支上面分出来的。修补结束以后,再合并进Master和Develop分支。它的命名,可以采用fixbug-*的形式。 

6).其它分支 other

还有就是其它分支了,大家可以根据需要创建即可…… 

9.团队多人开发协作 

在上面的章节中我们讲解了Git的分支管理策略,一般开发团队中有这样几个分支,master、develop、feature、release、 bug、other分支,或者你还有其它分支,那有博友会问了,你讲了那么多分支,都在本地放着我们怎么查看和推送分支到远程服务器上呢?嘿嘿,我们说大 家别急我们在这一章节中就来重点讲解,在团队多人协作中的分支推送与抓取。 

1).查看远程仓库分支

查看远程仓库的信息,如下图: 

大家可以看到git remote命令可以查看远程仓库,加-v选项可以查看详细信息。上面显示了你抓取和推送的origin(源)信息。 当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且远程仓库的默认名称是origin。 

2).分支推送

下面我们来演示一下将本地分支推送到远程的仓库中,如下图: 

大家可以看到,我们的本地master分支与远程的master分支已同步。下面我们来演示一下同步dev分支,如下图: 

我本地有很多分支,有哪些分支需要推送到远程仓库中呢?一般是这样的, 

  • master 分支是主分支,要时刻与远程同步,一般我们发布最新版本就用master分支 
  • develop 分支是开发分支,团队中所有人都在这个分支上开发,所以也需要与远程同步 
  • bug 分支一般只在本地使用来修复bug,一般不需推送远程仓库中 
  • feature 分支是否需要推送到远程,要看是不是有几个人合作开发新功能,如果你是一个开发,那就留在本地吧 
  • release 分支一般是系统管理,推送或抓取的分支一般与开发人员无关 
  • other 分支大家按需求分配 

3).分支抓取

现在你一同事在电脑上克隆一份仓库,我们来演示一下。 

生成公钥: 

将生成的公司增加到git服务器上: 

克隆远程版本库: 

我们现在查看一下分支: 

你同事要在dev分支上开发,就得创建与远程origin一样的dev分支到本地的仓库上,下面我们来创建一下: 

现在你同事就可以在dev分支上开发了,下面我们新建一些文件并提交到远程dev分支: 

你的同事向origin/dev分支提交了一个index.html页面,现在你也在修改这个文件,并提交: 

推送失败,因为你同事的最新提交和你推送的提交有冲突,Git提示我们,先用git pull把最新的提交从origin/dev抓下来,然后在本地合并解决冲突,再推送: 

git pull 失败了,原因是没有将dev分支与远程origin/dev分支进行链接,Git提示我们设置dev和origin/dev的链接: 

下面我们再来git pull一下试试: 

git pull 成功,但是合并有冲突需要手动解决,解决的方法和分支管理中的解决冲突完全一样。解决后提再push: 

好了,这样的我们的远程推送与抓取就讲解完成了,下面我们来总结一下。 

10.总结 

一般在团队中多人开发模式是这样的:首先,可以试图用git push origin branch-name推送自己的修改如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并如果合并有冲突,则解决冲突,并在本地提交没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name。 

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

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

相关文章

记录:微星 GE63 屏轴断裂 之后。。。

2022/11/25 记录 微星 GE63 1070 笔记本&#xff0c;使用的第三年&#xff0c;已过保了一年&#xff0c;上周使用时&#xff0c;准备合上笔记本盖。啪一下&#xff0c;左侧屏轴断裂&#xff0c;B面翘起&#xff0c;A面左下角轴盖断了一截。 网上好多人都有类似的情况&#xff…

晶振在单片机中扮演着什么角色?晶振坏了单片机还能运行程序吗?

晶振坏了单片机还能运行程序吗&#xff1f;前言晶振是什么&#xff1f;单片机没有晶振可以运行程序吗&#xff1f;PCB中晶振电路的要求结语前言 今天突然想到一个问题&#xff0c;如果一个单片机的晶振坏了那单片机还能运行程序吗&#xff1f;带着这个问题我查询了很多的治疗发…

HTML5期末考核大作业 基于HTML+CSS+JavaScript沪上美食(9页)

&#x1f380; 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

我的DW个人网站设计——安徽宣城6页HTML+CSS+JavaScript

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

SpringBoot+Mybaits搭建通用管理系统实例十:基础增删改查功能实现下

一、本章内容 实现系统基础增删改查功能,使用抽象类实现基础增删改查功能,包括数据详情加载、列表加载、分页加载、数据删除、批量删除、数据保存、数据更新等功能。 完整课程地址 二、开发视频 SpringBoot+Mybaits搭建通用管理系统实例二:service层实现 三、代码实现 3.1 删…

Flutter高仿微信-第48篇-群聊-图片

Flutter高仿微信系列共59篇&#xff0c;从Flutter客户端、Kotlin客户端、Web服务器、数据库表结构、Xmpp即时通讯服务器、视频通话服务器、腾讯云服务器全面讲解。 详情请查看 效果图&#xff1a; 详情请参考Flutter高仿微信-第44篇-群聊&#xff0c; 这里只是群聊的图片实现代…

NeRF~

NeRF实在太重要了代表着计算机视觉、图像学结合的未来重要方向&#xff1b;NeRF对于计算机视觉背景的同学有一定的理解门槛&#xff0c;本次试图以最小背景知识补充、最少理解成本为前提介绍NeRF。 NeRF&#xff0c;即Neural Radiance Fields&#xff08;神经辐射场&#xff0…

【语音识别】动态时间规整算法(RTW)语音识别系统【含GUI Matlab源码 341期】

⛄一、动态时间规整算法&#xff08;RTW&#xff09;语音识别 软件算法主要分为语音信号滤波去噪、预加重、分帧、端点检测、特征参数提取、模式匹配。算法的关键点和难点是特征参数提取和模式匹配。孤立词的语音识别应用程序也是基于MATLAB的GUI进行开发。 1 语音预处理 语音…

C++11标准模板(STL)- 算法(std::lower_bound)

定义于头文件 <algorithm> 算法库提供大量用途的函数&#xff08;例如查找、排序、计数、操作&#xff09;&#xff0c;它们在元素范围上操作。注意范围定义为 [first, last) &#xff0c;其中 last 指代要查询或修改的最后元素的后一个元素。 返回指向第一个不小于给定…

Hystrix原理

背景 分布式系统环境下&#xff0c;服务间类似依赖非常常见&#xff0c;一个业务调用通常依赖多个基础服务。如下图&#xff0c;对于同步调用&#xff0c;当库存服务不可用时&#xff0c;商品服务请求线程被阻塞&#xff0c;当有大批量请求调用库存服务时&#xff0c;最终可能…

jupyter中安装scala和spark内核详细教程

jupyter中安装scala和spark内核 jupyter中安装scala和spark内核 文章目录jupyter中安装scala和spark内核一、前期准备二、安装&#xff08;一&#xff09;Anaconda1、文件上传到Linux系统上方法一&#xff1a;方法二&#xff1a;使用wget2、安装Anaconda3、激活环境4、jupyter…

一文剖析Linux内核中内存管理

Linux中内存管理 内存管理的主要工作就是对物理内存进行组织&#xff0c;然后对物理内存的分配和回收。但是Linux引入了虚拟地址的概念。 文章推荐&#xff1a; 关于如何快速学好&#xff0c;学懂Linux内核。内含学习路线 需要多久才能看完linux内核源码&#xff1f; ​​…

windows位图绘制(显示位图资源)LoadBitmap、CreateCompatibleDC、BitBlt、StretchBlt

位图绘制 位图相关 光栅图形-记录图像中每一点的颜色等信息。 矢量图形-记录图像算法、绘图指令等。 HBITMAP-位图句柄 位图的适用 1.在资源中添加位图资源&#xff08;在vs中点鼠标增加&#xff09; 2.在资源中加载位图LoadBitmap 3.创建一个与当前DC相匹配的DC&#xff08;内…

Js逆向教程-13浏览器和JS的关系/伪造浏览器环境 )

作者&#xff1a;虚坏叔叔 博客&#xff1a;https://xuhss.com 早餐店不会开到晚上&#xff0c;想吃的人早就来了&#xff01;&#x1f604; Js逆向教程-13浏览器和JS的关系/伪造浏览器环境 ) 一、浏览器必然包含几个部分&#xff1a; 显示区域、输入网址、刷新按钮DOMBOM运行…

计算机网络笔记【面试】

计算机网络笔记【面试】前言推荐计算机网络笔记二、基础篇三、HTTP篇四、TCP 篇4.1 TCP 三次握手与四次挥手面试题什么是 TCP &#xff1f;UDP 和 TCP 有什么区别呢&#xff1f;分别的应用场景是&#xff1f;TCP 连接建立TCP 三次握手过程是怎样的&#xff1f;为什么是三次握手…

Aspose.Slides 21.11.0 For .NET Crack

适用于 .NET 的 Aspose.Slides 用于 PowerPoint 文件格式的 .NET API 在 .NET C# 中读取、写入、修改、合并、克隆、保护和转换 PowerPoint 和 OpenOffice 演示文稿&#xff0c;无需任何外部软件。 Aspose.Slides for .NET 是一个用于 PowerPoint 和 OpenOffice 格式的演示文稿…

Linux Mint 的更新管理器现在支持 Flatpak

导读Linux Mint 的更新管理器变得更有用了&#xff01; Linux Mint 的更新管理器是该发行版的一个重要组成部分&#xff0c;它使新用户可以获得更为方便简易的体验。 最近的一次更新 Linux Mint 21 推出了许多改进&#xff0c;包括更新管理器对 Flatpak 的支持。 你只需要更新…

【每周CV论文推荐】初学模型蒸馏值得阅读的文章

欢迎来到《每周CV论文推荐》。在这个专栏里&#xff0c;还是本着有三AI一贯的原则&#xff0c;专注于让大家能够系统性完成学习&#xff0c;所以我们推荐的文章也必定是同一主题的。模型蒸馏是非常重要的模型压缩方法&#xff0c;在学术界研究非常广泛&#xff0c;本次我们来简…

HTML5期末考核大作业网站——卫生与健康HTML+CSS+JavaScript

&#x1f380; 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

SpringBoot SpringBoot 原理篇 1 自动配置 1.14 自动配置思想

SpringBoot 【黑马程序员SpringBoot2全套视频教程&#xff0c;springboot零基础到项目实战&#xff08;spring boot2完整版&#xff09;】 SpringBoot 原理篇 文章目录SpringBootSpringBoot 原理篇1 自动配置1.14 自动配置思想1.14.1 自动配置原理1 自动配置 1.14 自动配置思…