一、分支介绍

在版本控制过程当中,有时候需要同时推进多个任务,这样的话,就可以给每个任务创建单独的分支。

有了分支之后,对应的开发人员就可以把自己的工作从主线上分离出来,在做自己分支开发的时候,不会影响到主线分支的运行。



如图所示:

  1. 要开发个新功能,加个蓝色背景。那么从master上建一个分支feature-blue,开发完后,合回到master。
  2. 同时另外一个新功能也要做,给系统加个小游戏。同样上建一个分支feature-game进行开发。
  3. 发现feature-blue上有个bug,那么再从master上建一个热修复分支hot-fix进行bug修改,完事后合到master。

所以,在众多分支并行开发的时候,master上的代码是正常在服务器上运行的,不会被影响。

故使用分支有如下优点:

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

二、分支操作

1. 查看分支

git branch -v

可以查看当前本地库有多少分支,其中*表示当前所在的分支。

2. 创建分支

git branch 分支名

创建完成后,再次查看分支,就可以看到新建的分支hot-fix

3. 切换分支

当前所在还是master分支,我不想动master分支的内容,希望在hot-fix分支上进行修改,那么现在切换到目标分支。

git checkout 分支名



已经切换成功。

现在我可以在hot-fix分支下进行文件内容的修改了,我改动hello.txt的第一行内容。

然后git add hello.txtgit commit -m "hot-fix first commit" hello.txt



cat hello.txt可以查看文本内容,在git里 linux命令通用。

4. 合并分支

正常合并

hot-fix修改完内容提交之后,现在切换回master分支,并且查看文件内容,发现还是原来的样子,没有受到影响。

现在我要把hot-fix上的内容合并到master上:

git merge 分支名

注意,这里是把命令行后输入的分支 合并到 当前所在分支,所以我先要切回到master上,才可以把hot-fix合过来。

合并完成,查看master分支上的文件内容,发现hot-fix上新增的内容已经合并了过来。

冲突合并

合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改,这就产生了冲突,这也是团队协助中最常见的场景之一了。

此时,git无法决定使用哪一个,所以必须人为的决定新代码的内容。

现在来造成一个冲突的场景:

  1. master分支,在hello.txt的最后一行末尾,增加新内容-"master test"。
  2. 切换到hot-fix分支,在hello.txt的最后一行末尾,增加新内容-"hot-fix test"。
  3. 切换到master分支,合并hot-fix分支。

提示自动合并失败,因为在hello.txt里面产生了冲突,此时查看git status,也可以看到提示。

OK,git处理不了,只能我们亲自出马了。此时可以打开文件vim hello.txt,会发现在文件里有冲突的提示。

有3个提示:

  • <<<<<<< HEAD,表示当前分支。
  • =======,相当于分界线,等号与上面的HEAD之间,是当前分支的代码。等号与下面的 hot-fix,是要合并过来的代码。
  • >>>>>>> hot-fix,要合并过来的分支。

现在我手动处理,希望2个分支的代码都保留,那么我留下这2行代码,把其余的提示信息去掉即可。

完成后进行git add hello.txt

注意,在接下来的git commit操作中,就不要带文件名了,否则会报错,如下:

git此时还是不知道用哪个分支的hello.txt,所以提交的时候不要带文件名了。

可以看到合并成功,接着查看下文件内容,cat hello.txt,结果如愿以偿。

注意,这里合并时候的修改,也只是改了master分支的文件内容,hot-fix分支是不受影响的,可以切到hot-fix查看文件内容便知。

分支原理

跟版本切换一样,分支切换的底层同样是指针。

上面的2个分支masterhot-fix,其实都是指向具体版本记录的指针。而当前所在的分支,其实是有HEAD决定的,HEAD指向哪个分支,现在就在那个分支上。

所以,创建分支的本质就是多创建一个指针,故切换分支的本质就是移动HEAD指针。

接下来是git的团队协助相关内容。

【Git】3. Git重要特性-分支操作,合并冲突详解的更多相关文章

  1. svn branch and merge(svn切换分支和合并)详解

    下文的实践主要是参考了TortoiseSVN的帮助文档和Subversion的在线文档,Subversion的在线文档:http://svnbook.red-bean.com/en/1.5/svn-b ...

  2. python操作redis用法详解

    python操作redis用法详解 转载地址 1.redis连接 redis提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用 ...

  3. 减少HTTP请求之合并图片详解(大型网站优化技术)

    原文:减少HTTP请求之合并图片详解(大型网站优化技术) 一.相关知识讲解 看过雅虎的前端优化35条建议,都知道优化前端是有多么重要.页面的加载速度直接影响到用户的体验.80%的终端用户响应时间都花在 ...

  4. IOS数据库操作SQLite3使用详解(转)

    iPhone中支持通过sqlite3来访问iPhone本地的数据库.具体使用方法如下1:添加开发包libsqlite3.0.dylib首先是设置项目文件,在项目中添加iPhone版的sqlite3的数 ...

  5. [转]使用python来操作redis用法详解

    转自:使用python来操作redis用法详解 class CommRedisBase(): def __init__(self): REDIS_CONF = {} connection_pool = ...

  6. C语言对文件的操作函数用法详解2

    fopen(打开文件) 相关函数 open,fclose 表头文件 #include<stdio.h> 定义函数 FILE * fopen(const char * path,const  ...

  7. C语言对文件的操作函数用法详解1

    在ANSIC中,对文件的操作分为两种方式,即: 流式文件操作 I/O文件操作 一.流式文件操作 这种方式的文件操作有一个重要的结构FILE,FILE在stdio.h中定义如下: typedef str ...

  8. iBatis——自动生成DAO层接口提供操作函数(详解)

    iBatis——自动生成DAO层接口提供操作函数(详解) 在使用iBatis进行持久层管理时,发现在使用DAO层的updateByPrimaryKey.updateByPrimaryKeySelect ...

  9. Python API 操作Hadoop hdfs详解

    1:安装 由于是windows环境(linux其实也一样),只要有pip或者setup_install安装起来都是很方便的 >pip install hdfs 2:Client——创建集群连接 ...

随机推荐

  1. ES6学习笔记(2)- 箭头函数

    1. 箭头函数声明 箭头函数的声明方式示例: 1 const printValue = (condition) => { 2 let testValue = 55; 3 if (conditio ...

  2. Mybatis最权威的知识点

    1.什么是Mybatis? (1)Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动.创建连接.创建statement ...

  3. (3)MySQL进阶篇SQL优化(索引)

    1.索引问题 索引是数据库优化中最常用也是最重要的手段之一,通过索引通常可以帮助用户解决大多数 的SQL性能问题.本章节将对MySQL中的索引的分类.存储.使用方法做详细的介绍. 2.索引的存储分类 ...

  4. Hi3559AV100 NNIE开发(6)RFCN中NNIE实现关键线程函数->SAMPLE_SVP_NNIE_Rfcn_ViToVo()进行数据流分析

    前面随笔给出了NNIE开发的基本知识,下面几篇随笔将着重于Mobilefacenet NNIE开发,实现mobilefacenet.wk的chip版本,并在Hi3559AV100上实现mobilefa ...

  5. 全网最详细的Linux命令系列-nl命令

    nl命令在linux系统中用来计算文件中行号.nl 可以将输出的文件内容自动的加上行号!其默认的结果与 cat -n 有点不太一样, nl 可以将行号做比较多的显示设计,包括位数与是否自动补齐 0 等 ...

  6. flexbox(弹性盒布局模型),以及适用场景

    一.是什么 Flexible Box 简称 flex,意为"弹性布局",可以简便.完整.响应式地实现各种页面布局 采用Flex布局的元素,称为flex容器container 它的所 ...

  7. Distributed | Paxos

    自Paxos问世以来就持续垄断了分布式一致性算法,Paxos这个名词几乎等同于分布式一致性.Google的很多大型分布式系统都采用了Paxos算法来解决分布式一致性问题.在学习了Raft算法之后自然不 ...

  8. [Fundamental of Power Electronics]-PART I-1.引言-1.2 1.3 电力电子技术的几个应用、本书内容

    1.2 电力电子技术的几个应用 高效开关变换器面临的功率范围从 (1)小于1瓦(电池供电的便携式设备内的DC-DC转换器)到(2)计算机及办公设备中的几十,几百,数千瓦到(3)变速电机驱动器中上千瓦及 ...

  9. 【C/C++】面向对象开发的优缺点

    原创文章,转发请注明出处. 面向对象开发的优缺点 面向对象开发 是相对于 面向过程开发 的一种改进思路. 由于流水线式的面相过程开发非常直接,高效.在面对一些简单项目时,只需要几百行,甚至是几十行代码 ...

  10. Java中获取类的运行时结构

    获取运行时类的完整结构 通过反射获取运行时类的完整结构 Field(属性).Method(方法).Constructor(构造器).Superclass(父类).Interface(接口).Annot ...