笔记四:git分支

一:学习内容

  • git分支特性
  • git分支操作-查看分支
  • git分支操作-创建分支
  • git分支操作-切换和修改分支
  • git分支操作-分支合并
  • git分支操作-代码合并冲突解决

 

二:git分支特性

1.什么是分支?

在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。

使用分支,程序员就可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。

可以简单理解为分支即为副本,一个分支就是一个单独的副本(分支的底层其实也是指针的引用)。

 

master、hot-fix等分支其实都是指向具体版本记录的指针。当前所在的分支,其实是由HEAD决定的,所以创建分支的本质就是多创建一个指针。【head如何指向master,那么我们现在就在master分支上,head如果指向hot-fix,那么我们现在就在hot-fix分支上。】所以切换分支的本质就是移动HEAD指针。

 

2.分支的好处

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

 

三:git分支操作

1.命令汇总

1 git branch 分支名:创建分支
2 git branch -v:查看分支
3 git checkout 分支名:切换分支
4 git merge 分支名:把指定的分支合并到当前分支上

 

2.查看分支

1 #查看分支
2 git branch -v

命令执行结果如下:

 

3.创建分支

1 #创建一个分支,名为hot-fix,它会自动拷贝master分支指针当前指向的版本的内容
2 git branch hot-fix
3 
4 #再次查看分支,此时发现有2个分支了
5 git branch -v

命令执行结果如下:

 

4.切换和修改分支

 1 #当前在master分支上,修改hot-fix分支内容,则需要切换分支
 2 git checkout hot-fix
 3 
 4 #再次查看分支,此时发现*号指向了hot-fix,说明分支已经切换到hot-fix分支上了
 5 git branch -v
 6 
 7 #修改hot-fix分支上的内容
 8 vim hello.txt
 9 git status
10 git add hello.txt
11 git commit -m "hot-fix first commit" hello.txt
12 
13 #在hot-fix分支上查看版本精简信息
14 git reflog

命令执行结果如下:

从master分支切换到hot-fix分支:

 

修改hot-fix分支上的内容并提交本地库:

 

查看hot-fix分支上版本精简信息:下方截图从最后一行往上读便是版本经历过程
①8b94833 HEAD@{7}: commit (initial): first commit:在master分支上,第一次提交,版本号为8b94833
②dbb4e24 HEAD@{6}: commit: second commit:在master分支上,第二次提交,版本号为dbb4e24
③f5ad1d9 (master) HEAD@{5}: commit: third commit:在master分支上,第三次提交,版本号为f5ad1d9

④dbb4e24 HEAD@{4}: reset: moving to dbb4e24:在master分支上,从第三次版本穿梭到第二次版本
⑤8b94833 HEAD@{3}: reset: moving to 8b94833:在master分支上,从第二次版本穿梭到第一次版本
⑥f5ad1d9 (master) HEAD@{2}: reset: moving to f5ad1d9:在master分支上,从第一次版本穿梭到第三次版本

⑦f5ad1d9 (master) HEAD@{1}: checkout: moving from master to hot-fix:从master分支切换到hot-fix分支

⑧d33c235 (HEAD -> hot-fix) HEAD@{0}: commit: hot-fix first commit:在hot-fix分支上,第一次提交,版本号为d33c235

 

5.合并分支-正常合并

1 #将hot-fix分支上的当前指针指向的版本,合并到master分支上
2 #首先需要切换到master分支上
3 git checkout master
4 
5 #然后合并分支
6 git merge hot-fix

命令执行结果如下

从hot-fix分支切换到master分支上:

合并分支:

 

👉说明:已知:
master分支:
8b94833:first commit
dbb4e24:second commit
f5ad1d9:third commit

hot-fix分支:
d33c235:hot-fix first commit
aacf318:hot-fix second commit

test分支:
51c56ed:test分支第1次提交
4e37885:test分支第2次提交

注意:这里合并并不是合并该分支的最新版本,而是该分支当前指针指向哪个版本就合并哪个版本。
如:test分支当前指针指向版本为第一次提交的51c56ed,然后切换到master分支,合并test分支,则会将test分支的第一次提交的51c56ed版本覆盖掉master分支指针指向的当前版本内容。

 

6.合并分支-产生冲突

>产生冲突的原因:合并分支时,两个分支在同一个文件的相同区域(行、段落)有两套完全不同的修改。git无法决定使用哪一个,必须人为决定新代码内容。

>注意:这里的修改是指已经存在子分支了,在对master和子分支分别修改

 1 #已存在master和hot-fix两个分支
 2 #先对master分支进行修改,对hello.txt最后一行加上master gai,然后add,最后commit
 3 git checkout master
 4 vim hello.txt
 5 git add hello.txt
 6 git commit -m "master gai" hello.txt
 7 
 8 
 9 #再对hot-fix分支进行修改,对hello.txt最后一行加上hot-fix gai,然后add,最后commit
10 git checkout hot-fix
11 vim hello.txt
12 git add hello.txt
13 git commit -m "hot-fix gai" hello.txt
14 
15 
16 #切回master,将hot-fix合并到master上,会出现合并冲突
17 git merge hot-fix

命令执行结果如下:

 

7.合并分支-解决冲突

1 #直接在master分支上,手动修改冲突,删除特殊字符和不想要的代码,留下你想要的代码
2 vim hello.txt
3 
4 #修改后的文件,需要添加暂存区并提交本地库
5 git add hello.txt
6 
7 #提交本地库,注意这里不要加hello.txt了,提交成功后只会修改合并后的分支也就是master分支的内容,不会修改hot-fix分支的内容
8 git commit -m "merge test"

命令执行结果:

手动修改冲突:删除特殊字符和不想要的代码,留下你想要的代码

修改文件添加暂存区并提交本地库:

 

posted @ 2023-03-11 20:35  秒秒开心  阅读(175)  评论(0编辑  收藏  举报