目录
1、什么是分支
在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。
分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。
现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。
其他版本控制系统如SVN等都有分支管理,但是用过之后你会发现,这些版本控制系统创建和切换分支比蜗牛还慢,简直让人无法忍受,结果分支功能成了摆设,大家都不去用。
但Git的分支是与众不同的,无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是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 操作案例
创建temp
分支
3.3 切换分支
3.3.1、命令
git checkout 分支名
3.3.2 操作案例
从master
分支切换到temp
分支
3.4 合并分支
3.3.1、命令
git merge 分支A
解释:将分支A
合并到当前分支
3.3.2 操作案例(没有冲突)
3.3.3 操作案例(冲突合并)
冲突产生的原因:
合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。Git 无法替我们决定使用哪一个。必须人为决定新代码内容。
手动解决冲突:
编辑有冲突的文件,删除特殊符号,决定要使用的内容。手动处理冲突后,重新提交并推送到远端,完成分支合并。
特殊符号:<<<<<<< HEAD
当前分支的代码
=======
合并过来的分支代码
>>>>>>> 合并过来的分支名称