【Git】3. Git重要特性-分支操作,合并冲突详解
一、分支介绍
在版本控制过程当中,有时候需要同时推进多个任务,这样的话,就可以给每个任务创建单独的分支。
有了分支之后,对应的开发人员就可以把自己的工作从主线上分离出来,在做自己分支开发的时候,不会影响到主线分支的运行。
如图所示:
- 要开发个新功能,加个蓝色背景。那么从master上建一个分支feature-blue,开发完后,合回到master。
- 同时另外一个新功能也要做,给系统加个小游戏。同样上建一个分支feature-game进行开发。
- 发现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.txt
和git 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无法决定使用哪一个,所以必须人为的决定新代码的内容。
现在来造成一个冲突的场景:
- 在
master
分支,在hello.txt的最后一行末尾,增加新内容-"master test"。 - 切换到
hot-fix
分支,在hello.txt的最后一行末尾,增加新内容-"hot-fix test"。 - 切换到
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个分支master
和hot-fix
,其实都是指向具体版本记录的指针。而当前所在的分支,其实是有HEAD决定的,HEAD指向哪个分支,现在就在那个分支上。
所以,创建分支的本质就是多创建一个指针,故切换分支的本质就是移动HEAD指针。
接下来是git的团队协助相关内容。
【Git】3. Git重要特性-分支操作,合并冲突详解的更多相关文章
- svn branch and merge(svn切换分支和合并)详解
下文的实践主要是参考了TortoiseSVN的帮助文档和Subversion的在线文档,Subversion的在线文档:http://svnbook.red-bean.com/en/1.5/svn-b ...
- python操作redis用法详解
python操作redis用法详解 转载地址 1.redis连接 redis提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用 ...
- 减少HTTP请求之合并图片详解(大型网站优化技术)
原文:减少HTTP请求之合并图片详解(大型网站优化技术) 一.相关知识讲解 看过雅虎的前端优化35条建议,都知道优化前端是有多么重要.页面的加载速度直接影响到用户的体验.80%的终端用户响应时间都花在 ...
- IOS数据库操作SQLite3使用详解(转)
iPhone中支持通过sqlite3来访问iPhone本地的数据库.具体使用方法如下1:添加开发包libsqlite3.0.dylib首先是设置项目文件,在项目中添加iPhone版的sqlite3的数 ...
- [转]使用python来操作redis用法详解
转自:使用python来操作redis用法详解 class CommRedisBase(): def __init__(self): REDIS_CONF = {} connection_pool = ...
- C语言对文件的操作函数用法详解2
fopen(打开文件) 相关函数 open,fclose 表头文件 #include<stdio.h> 定义函数 FILE * fopen(const char * path,const ...
- C语言对文件的操作函数用法详解1
在ANSIC中,对文件的操作分为两种方式,即: 流式文件操作 I/O文件操作 一.流式文件操作 这种方式的文件操作有一个重要的结构FILE,FILE在stdio.h中定义如下: typedef str ...
- iBatis——自动生成DAO层接口提供操作函数(详解)
iBatis——自动生成DAO层接口提供操作函数(详解) 在使用iBatis进行持久层管理时,发现在使用DAO层的updateByPrimaryKey.updateByPrimaryKeySelect ...
- Python API 操作Hadoop hdfs详解
1:安装 由于是windows环境(linux其实也一样),只要有pip或者setup_install安装起来都是很方便的 >pip install hdfs 2:Client——创建集群连接 ...
随机推荐
- 追洞小组 | fastjson1.2.24复现+分析
出品|MS08067实验室(www.ms08067.com) 本文作者:爱吃芝士的小葵(Ms08067实验室追洞小组成员) 1.靶场搭建 2.漏洞复现 3.漏洞分析 4.漏洞修复 5.心得 靶场搭建 ...
- 源码解析之 Mybatis 对 Integer 参数做了什么手脚?
title: 源码解析之 Mybatis 对 Integer 参数做了什么手脚? date: 2021-03-11 updated: 2021-03-11 categories: Mybatis 源码 ...
- TensorFlow2.0使用方法
TensorFlow2.0 1 使用技巧 更新到最新版本: pip install --upgrade tensorflow pip install --upgrade tensorflow-gpu ...
- 「NOIP模拟赛」Round 3
Tag 计数+LIS, 二分+ST表, 计数+记搜 A. 改造二叉树 Description 题面 Solution 如果目标序列非严格递增,或者说目标序列是不下降的,那么答案就是 \(n\) 减去最 ...
- 推荐模型DeepCrossing: 原理介绍与TensorFlow2.0实现
DeepCrossing是在AutoRec之后,微软完整的将深度学习应用在推荐系统的模型.其应用场景是搜索推荐广告中,解决了特征工程,稀疏向量稠密化,多层神经网路的优化拟合等问题.所使用的特征在论文中 ...
- SSM-员工管理项目实战-CRUD-增删改查
SSM-CRUD 一.项目简介 主界面演示 功能点 分页 数据校验 ajax Rest 风格的 URI 技术点 基础框架 - ssm(Spring + SpringMVC + MyBatis) 数据库 ...
- java例题_18 乒乓球比赛(对手问题)
1 /*18 [程序 18 乒乓球赛] 2 题目:两个乒乓球队进行比赛,各出三人.甲队为 a,b,c 三人,乙队为 x,y,z 三人.已抽签决定比赛名单. 3 有人向队员打听比赛的名单.a说他不和 x ...
- shiro报错SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".和Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
未能加载类"org.slf4j.impl.StaticLoggerBinder" 解决方案: <dependency> <groupId>org.slf4j ...
- [BFS]骑士旅行
骑士旅行 Description 在一个n m 格子的棋盘上,有一只国际象棋的骑士在棋盘的左下角 (1;1)(如图1),骑士只能根据象棋的规则进行移动,要么横向跳动一格纵向跳动两格,要么纵向跳动一格横 ...
- day-06-集合-缓存机制-深浅copy
(1) is id ==用法 is 判断的是内存地址是否相同 id 查看内存地址:id相同,值一定相同,值相同,id不一定相同 == 比较判断是否相等 l1 = [1, 2, 3] l2 = [1, ...