一、分支介绍

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

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



如图所示:

  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. C#关于个Base64,MD5,16进制的转换

    1,待签名数据以UTF-8的格式转字节流,对字节流进行MD5算法得到的签名字节流,再转换为16进制字符串,即生成了数字签名. byte[] targetData = md5.ComputeHash(S ...

  2. python 画图中文显示问题

    在python文件当前目录下添加simsun.ttc(资源网上下载即可,有很多) 代码如下: plt.title("标题", fontproperties='SimHei', si ...

  3. linux 系统用户与用户组管理

    关于/etc/passwd和/etc/shadow /etc/passwd 第1个字段为用户名(第一行中的root就是用户名)第2个字段存放的是该账号的口令.第3个字段为一个数字,这个数字代表的用户标 ...

  4. P1423_小玉在游泳(JAVA语言)

    题目描述 小玉开心的在游泳,可是她很快难过的发现,自己的力气不够,游泳好累哦. 已知小玉第一步能游2米,可是随着越来越累,力气越来越小, 她接下来的每一步都只能游出上一步距离的98%. 现在小玉想知道 ...

  5. 解决无法通过浏览器访问docker成功安装rabbitMQ后页面问题

    我发现了问题后,花了两天的时间解决了这个问题. 一.测试在docker本机中使用curl "ip地址:端口" 查看是否能访问成功,结果是没问题,排除了docker安装失败的问题 二 ...

  6. 对象存储服务-Minio

    Mino 目录 Mino 对象存储服务 Minio 参考 Minio 架构 为什么要用 Minio 存储机制 纠删码 MinIO概念 部署 单机部署: Docker 部署Minio 分布式Minio ...

  7. 比Django官方实现更好的分页组件+Bootstrap整合

    前言 Django全家桶自带的分页组件只能说能满足分页这个功能,但是没那么好用就是了 Django的分页效果 django-pure-pagination分页效果 使用方法 首先安装: pip ins ...

  8. 「HTML+CSS」--自定义加载动画【005】

    前言 Hello!小伙伴! 首先非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出- 哈哈 自我介绍一下 昵称:海轰 标签:程序猿一只|C++选手|学生 简介:因C语言结识编程,随后转入计算机 ...

  9. MarkDown-简单学习

    标题 注意:首部添加1-6个"#"号来设置标题大小: 字体 1:粗体 (注意:首尾同时添加2个"*"号来设置) 2:斜体 (注意:首尾同时添加1个"* ...

  10. 关于一次配合开发工作而产生的服务器内核参数问题(Android 网络问题)

    关于一次配合开发工作而产生的服务器内核参数问题(Android 网络问题) 问题转载(本人与作者遇到了同样的问题) 问题描述 问题描述:在这几年的Android开发中,遇到了一个困扰我好久的问题,有时 ...