Git分支操作

在这里插入图片描述

什么是分支

在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。对于初学者而言,分支可以简单理解为副本,一个分支就是一个单独的副本。(分支底层其实也是指针的引用)

分支的好处

同时并行推进多个功能开发,提高开发效率。
各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

分支的操作

命令名称作用
git branch 分支名创建分支
git branch -v查看分支
git checkout 分支名切换分支
git merge 分支名把指定的分支合并到当前分支上

查看、创建、切换分支

基本语法

git branch -v

在这里插入图片描述

git branch hot-fix

在这里插入图片描述

git checkout hot-fix

在这里插入图片描述
修改hello.txt文件,并提交到本地库中:

vim hello.txt
git status
git add hello.txt 
git status
git commit -m "hot-fix first commit" hello.txt
git reflog

在这里插入图片描述

合并分支

基本语法:
将目标分支合并到当前所在分支中:

git merge hot-fix 

在这里插入图片描述

产生冲突

产生冲突的原因:合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。Git无法替我们决定使用哪一个。必须人为决定新代码内容。

冲突产生的表现:后面状态为MERGING。

我们可以在master分支和hot-fix分支同一文件修改为不同的内容。

vim hello.txt
git add hello.txt
git commit -m "master test" hello.txt
git checkout hot-fix
vim hello.txt
git add hello.txt
git commit -m "hot-fix test" hello.txt
git checkout master
git merge hot-fix

在这里插入图片描述

git status

在这里插入图片描述

cat hello.txt

查看文件内容,会出现冲突部分的内容对比:

<<<<<<< HEAD
当前分支的内容
=======
合并分支的内容
>>>>>>> hot-fix

手动解决冲突:
修改master分支文件的内容。
将文件添加到暂存区:

git add hello.txt

执行提交(注意:此时使用git commit命令时不能带文件名)

git commit -m "merge test"

在这里插入图片描述
将分支切换为hot-fix,可以看到该分支内容并没有被改变:

git checkout hot-fix

master、hot-fix其实都是指向具体版本记录的指针。当前所在的分支,其实是由HEAD决定的。所以创建分支的本质就是多创建一个指针。

切换分支本质上就是移动HEAD指针。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值