Git:Git中的分支管理

简介: Git:Git中的分支管理

本篇主要总结的是Git中的分支管理

分支是什么

在Git中,一个强大的功能就是分支

由前面的学习可以知道,当我们每次进行commit的时候,Git都会把这些commit的操作穿成一个时间线,而这个时间线就可以理解为是一个分支,在我们前面的操作中,只有一个时间线,换而言之,只有一个分支,这个分支就叫做主分支,也叫做master分支

上一篇在介绍Git的基本操作中讲到,Git中含有HEAD指针,可以借助它来完成对于版本的回退,这里再次明确概念,这个HEAD指针所指向的内容是master而不是具体的commit记录,而master所指向的内容才是提交的内容,也就是说,HEAD指向的是当前分支,而分支指向的是具体的master提交记录,用下面一张图来表示:

提交线上的每一个圆圈,代表的都是每一次提交,而master指向的是最新的一次提交,用户本身利用HEAD指针就可以通过master的指向回退或快进到某一个版本,随着不断提交,这个分支会不断变长,但只要HEAD一直指向的是master分支就可以指向当前的分支

下面通过一些实验来看上面的理论:

上图中使用了一些命令来查看当中的commit相关信息,从中可以看出每一次提交的信息都有记录,并且也会记录它的上一次提交的相关信息,依据这些信息都可以在这条master分支线中找到相应的信息

创建分支

既然分支是Git中的一大重要操作,那么创建多分支并使用多分支进行管理项目也是必不可少的操作,那么如何新建分支?

这里提供两个命令

# 查看本地所有分支
git branch
# 新建分支dev
git branch dev

其中,*表示的内容是,当前Git所控制的分支,以上图为例,当前HEAD所指向的分支其实是master,同时上面也表明了在Git中如何创建一个分支

下图表示了分支的存在证明:

在我们创建了分支后,此时的refs路径下heads所包含的内容就不仅仅是master了,换句话说,HEAD可以指向其他内容了

分支切换

在Git中提供了切换分支的操作:

# dev表示要切换的分支名称
git checkout dev

利用上面的命令,将Git的分支实现了切换,下图为实践图

而切换分支的操作,实际上就是将HEAD指针所指向的分支做修改的一个过程:

从上图中可能还有疑问,为什么dev创建后的分支默认是指向最新提交处?后面会进行实验证明

那么切换完分支后,就可以进行一些操作验证分支的特性了

从上图的实验中可以看出,在没有进行合并分支的前提下,在不同的分支下进行的commit操作是不可以互通的,都是单独的时间线,也就是单独的分支,从commit id的视角下观察这个结论

从上面的实验中可以几点:新建的分支确实是在当前所指分支的开始新建的,并且新建后的分支内容和旧的分支内容并不互通,也就是说,此时的状态可以用下面的状态图表示

合并分支

那么如何进行分支合并?Git中也提供了相关的命令:

# 要切换到master分支下
git merge dev

当在master分支下使用指令合并分支后,test中的内容就被合并到master中了,此时master就重新指向了最新的分支节点

Fast-forward代表快进模式,也就是直接把master指向dev的当前提交

删除分支

分支使用后要进行删除,避免占用过多资源:

git branch -d dev

此时就删除掉了分支:

那创建分支合并分支删除分支有什么作用?

Git建议使用分支后再删除,这样比较安全

合并冲突

看下面的场景:

上面所演示的过程就是合并冲突的原理,两个分支都进行了一些操作,此时想要进行合并Git不知道该如何合并,该合并哪个部分,因此Git给出的解决方案是两个版本都进行保留,由用户自己来决定如何管理

用下图来表示这个冲突的过程:

因此,当手动删除了部分内容后并进行提交,就可以解决这个冲突问题,此时就可以把状态转换为:

Git的可视化流程图

Git命令中也是可以把上面的这个流程图进行可视化的,使用到的命令是git log

git log --graph --pretty=oneline --abbrev-commit

合并模式

merge的过程中,有两种合并模式,前面已经提到过一种合并模式是Fast-forward模式,这个模式的特点是直接将dev分支中的信息合并到master分支内,但如果这里我想在合并的这个过程也产生一次commit来表示,这里确实发生过一次merge该如何处理?Git中也提供了对应的命令选项:

# branch表示合并的分支名称
git merge --no-ff -m "merge with no-ff" [branch]

那么下面用实验来对比一下这两个方法合并模式对应的效果演示

首先看fast-forward模式

上面演示的就是fast-forward下的各项操作,下面演示no fast-forward的操作结果

从中可以看出,使用no-ff模式下的合并方法可以显示出merge的具体commit id等信息,这样有利于在追溯代码的时候找到在哪里产生问题等,在实际开发中也多建议使用no-ff模式而不是ff模式

分支策略

在实际开发中,进行分支管理应该要遵循下面的几个原则

  1. master版本是一个非常稳定的版本,这个分支是主分支,上面只是用来发布新的版本,在平时的开发过程中应该要自己创建分支,在自己的分支上完成操作
  2. 在自己的dev分支上完成自己的工作任务后,每个人都有自己的分支,完成后向master分支合并就可以了

因此整个合并的流程可以表示为下面的图

每个人都有自己的分支,分支写好后统一合并到master分支上,以确保master分支上都是稳定的代码

bug分支

现在有这样的场景,假设你正在dev的分支上进行开发,突然,master分支上发现了一个bug,现在这种修改master分支上的bug,应该如何解决?

在Git中,每一个bug都可以通过一个新的临时分支来进行修复,修复后合并分支,再将临时分支删除即可,但是对于上面的情况,dev的代码正在开发,但是master有问题,现在还无法提交,对于这种情况该如何解决?

针对这种情况,在Git中提供了一种叫做git stash的命令,这个命令的作用就是可以让当前的工作区的信息进行存储,在未来的某个时刻再把信息拿出来

git stash

使用该指令可以让工作区中的代码暂时存起来,因此使用stash指令查看就会发现此时工作区中是没有内容的,此时就可以单独拉一条fix_bug专用的分支进行修复代码,修复后的代码再提交到master分支内,此时master分支就是一个稳定的,没有bug的一份代码

那么下面就要解决的问题是,如何把我写了一半的代码和新的没有bug的代码合在一起

此时就完成了基本目标:既把master分支的bug改完了,又把dev分支下的内容更新完,并且dev下的内容是没有bug的,那么如何把dev的文件上传到master主线上?其实直接上传即可,但这里不推荐这样,原因如下:

原因是,解决合并冲突的时候,是由dev的用户自己进行手动的删除解决的,这当中可能会出现一些问题,因此这样的方法是有可能会出现错误的:

那么最标准的方法是,应该先拉取master上的代码与dev合并,在dev分支下看看能不能正常运行,如果可以再将代码整体合并到master分支上,以确保master分支上都是可跑的,没问题的代码

强制删除分支

Git默认的删除分支的前提是路径要进行合并后才能进行删除,但如果是没有进行合并,只是单纯想把路径删除?

Git中提供了对应的选项

# dev表示要删除的分支
git branch -D dev
相关文章
|
8月前
|
API 开发工具 git
《Git 简易速速上手小册》第3章:分支管理(2024 最新版)
《Git 简易速速上手小册》第3章:分支管理(2024 最新版)
110 1
|
8月前
|
开发工具 git
|
8月前
|
安全 开发工具 git
【Git】—— 分支管理策略
【Git】—— 分支管理策略
125 0
|
8月前
|
开发工具 git 开发者
git仓库分支管理
git仓库分支管理
|
18天前
|
运维 测试技术 持续交付
代码管理的艺术:你的团队是否还在为 Git 分支管理头疼?
本文回顾了作者从2~3人初创团队到百人技术团队的经历,分享了代码管理工具从无到SVN再到Git的演变。重点介绍了Git Flow和GitHub Flow两种常用的Git分支管理模型,分析了它们的适用场景和优缺点。Git Flow适合中大型项目,而GitHub Flow则更适合小型团队和Web应用开发。
45 0
|
2月前
|
开发工具 git
git分支管理master/hotfix/develop/feature/release
采用合理的Git分支管理模型可以显著提升团队协作效率和代码管理的质量。本文介绍的 `master`、`develop`、`feature`、`release`和 `hotfix`分支模型是一个行之有效的方法,适用于大多数软件开发项目。通过清晰地划分各个分支的职责,团队成员可以更专注于各自的开发任务,同时确保代码库的稳定性和可维护性。
74 2
|
2月前
|
测试技术 开发工具 git
掌握Git分支管理,提升团队协作效率
掌握Git分支管理,提升团队协作效率
39 0
|
3月前
|
开发工具 git
【Git快速入门】Git代码管理手册与协同开发之分支管理与协作(五)
【Git快速入门】Git代码管理手册与协同开发之分支管理与协作(五)
|
5月前
|
敏捷开发 小程序 持续交付
【规范】Git分支管理,看看我司是咋整的
本文介绍了Git分支管理规范的重要性及其在企业中的应用。通过规范化的分支管理,可加速团队协作、确保代码质量、维护主分支稳定,并支持敏捷开发。文中详细描述了主分支(如master、develop)和辅助分支(如feature、hotfix)的作用,并提供了实际开发流程示例,包括开发前、开发中、提测、预生产和部署上线等阶段的操作方法。旨在帮助团队提高效率和代码质量。
442 0
【规范】Git分支管理,看看我司是咋整的
|
8月前
|
开发工具 git