1 什么是分支
在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独 分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时 候,不会影响主线分支的运行。对于初学者而言,分支可以简单理解为副本,一个分支就是 一个单独的副本。(分支底层其实也是指针的引用)
2 、分支的好处
同时并行推进多个功能开发,提高开发效率。 各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。
失败 的分支删除重新开始即可。
3、分支的操作
3.1 查看分支
1)基本语法
git branch -v
2)案例实操
3.2 创建分支
1)基本语法
git branch 分支名
2)案例实操
刚创建的新分支,并将主分支master的内容复制了一份
3.3 修改分支
添加暂存区
提交本地库
查看分支
master 分支已经更新为最新一次提交版本
hot-fix分支并未作任何修改
1.4 切换分支
1)基本语法
git checkout 分支名
2)案例实操
查看该分支的文件,发现并没有被修改
在该分支上作修改
添加暂存区,提交本地库
1.5 合并分支
1)基本语法
git merge 分支名
2)案例实操
我们修改了master 和hot-fix分支 的hello.txt文件
在 master 分支上合并 hot-fix 分支
我们发现 合并失败了
1.6 产生冲突
当
冲突产生的表现:后面状态为 MERGING
冲突产生的原因:
合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。Git 无法替 我们决定使用哪一个。必须人为决定新代码内容。
查看状态(检测到有文件有两处修改)
1.7 解决冲突
1)编辑有冲突的文件,删除特殊符号,决定要使用的内容
特殊符号:<<<<<<< HEAD 当前分支的代码 ======= 合并过来的代码 >>>>>> hot-fix
2)添加到暂存区
3)执行提交(注意:此时使用 git commit 命令时不能带文件名)
master、hot-fix 其实都是指向具体版本记录的指针。
当前所在的分支,其实是由 HEAD 决定的。所以创建分支的本质就是多创建一个指针。
HEAD 如果指向 master,那么我们现在就在 master 分支上。
HEAD 如果执行 hotfix,那么我们现在就在 hotfix 分支上。
所以切换分支的本质就是移动 HEAD 指针。