1:什么是分支
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离 开来进行重大的Bug修改、开发新的功能,以免影响开发主线。 几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离 开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
2:分支的好处
同时并行推进多个功能开发,提高开发效率。
各个分支在开发过程中, 如果某一个分支开发失败, 不会对其他分支有任何影响。失败 的分支删除重新开始即可。
3:分支的操作
命令名称 | 作用 |
git branch 分支名 | 创建分支 |
git branch -v | 查看分支 |
git checkout 分支名 | 切换分支 |
git merge 分支名 | 把指定的分支合并到当前分支上 |
3.1:查看分支
1)基本语法
git branch -v
案例实操
3.2:创建分支
1)基本语法
git branch 分支名
2)案例实操
3.3:切换分支
1)基本语法
git checkout 分支名
2)案例实操
【第一步】切换分支到hot-fix,在hot-fix分支上做修改
修改内容如下:
3.4:合并分支
1)基本语法
git merge 分支名
2)案例实操 在 master 分支上合并 hot-fix 分支
【第一步】切换到master分支
【第二步】合并hot-fix分支
【第三步】查看文件内容
3.5:产生冲突
冲突产生的表现: 后面状态为 MERGING
冲突产生的原因:
合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。 Git 无法替 我们决定使用哪一个。必须人为决定新代码内容。
查看状态(检测到有文件有两处修改)
制造冲突:
【第一步】 切换到master分支上,修改hello.txt
修改内容如下
【第二步】 切换到hot-fix分支上,修改hello.txt
修改内容如下:
【第三步】 切换到master分支,merge合并 hot-fix分支
已经产生冲突!!!
3.6:解决冲突
1)编辑有冲突的文件,删除特殊符号,决定要使用的内容
特殊符号: <<<<<<< HEAD 当前分支的代码 ======= 合并过来的代码 >>>>>>> hot-fix
修改文件如下:
2)添加到暂存区
3)执行提交(注意: 此时使用git commit 命令时不能带文件名)
4)注意
我们修改的只是master分支的内容,hot-fix分支的内容没有发生改变
4:开发中分支使用原则与流程
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离 开来进行重大的Bug修改、开发新的功能,以免影响开发主线。 在开发中,一般有如下分支使用原则与流程:
master (生产) 分支 线上分支,主分支,中小规模项目作为线上运行的应用对应的分支;
develop(开发)分支 是从master创建的分支,一般作为开发部门的主要开发分支,如果没有其他并行开发不同期上线 要求,都可以在此版本进行开发,阶段开发完成后,需要是合并到master分支,准备上线。
feature/xxxx分支 从develop创建的分支,一般是同期并行开发,但不同期上线时创建的分支,分支上的研发任务完 成后合并到develop分支。
hotfix/xxxx分支, 从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、 develop分支。
还有一些其他分支,在此不再详述,例如test分支(用于代码测试)、pre分支(预上线分支)等 等。