目录
1、什么是分支
在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。对于初学者而言,分支可以简单理解为副本,一个分支就是一个单独的副本。(分支底层其实也是指针的引用)
2、分支的好处
同时并行推进多个功能开发,提高开发效率。
各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。
3、分支的操作
命令名称 | 作用 |
git branch 分支名 | 创建分支 |
git branch -v | 查看分支 |
git checkout 分支名 | 切换分支 |
git merge 分支名 | 把指定的分支合并到当前分支上 |
3.1、查看分支
3.1.1、基本语法
git branch -v
3.1.2、举例
3.2、创建分支
3.2.1、基本语法
git branch 分支名
3.2.2、举例
3.3、切换分支
3.3.1、基本语法
git checkout 分支名
3.3.2、举例
3.4、修改分支
3.5、合并分支
3.5.1、基本语法
注:是把指定的分支合并到当前分支上
git merge 分支名
3.5.2、举例
3.6、产生冲突
产生冲突的表现:后面状态为 MERGING
冲突产生的原因:合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。Git 无法替我们决定使用哪一个。必须人为决定新代码内容。
master、hot-fix 其实都是指向具体版本记录的指针。当前所在的分支,其实是由 HEAD决定的。所以创建分支的本质就是多创建一个指针。
HEAD 如果指向 master,那么我们现在就在 master 分支上。
HEAD 如果执行 hotfix,那么我们现在就在 hotfix 分支上。
所以切换分支的本质就是移动 HEAD 指针。
① 先在 master 分支修改 hello.txt(最后一行加 master test),并将其提交到工作区
② 切换到 hot-fix 分支,对 hello.txt 修改(倒数第二行加 hot-fix test),并提交到工作区
③ 切换到 master 分支,合并 hot-fix test,发现报错。查看状态爆红
④ 查看 hello.txt,这里忘记截图了,这里放一张修改一半的截图
真实格式为下图
⑤ 可以将多余的行,如 <<<<HEAD、=====、>>>>hot-fix还有不需要的重复行删掉并保存即可(删除行可以按 esc+dd ),且需要提交到工作区。提交完后分支名后面的 |MERGING 会消失