9.Git分支-分支的创建与合并-02
在 8.Git分支-分支的创建与合并-01 主要通过一个例子介绍了分支的新建,以及在工作中,git分支的新建切换以及使用,这里主要介绍分支的合并。这里的例子和8.Git分支-分支的创建与合并-01 的例子是连在一起的。
1.分支合并(没有冲突)
分支合并主要使用:git merge <branch-name>
接上一篇的例子:
1.现在你关于defect #53的开发也已经完成了,现在branch的情况如下图所示。

2.你只需要运行下面两条命令,就能够将你在iss53上面的代码合并到master分支上了。
git checkout master
git merge iss53
合并之后的分支情况如下图所示。在执行git merge命令的时候,Git会将master分支和iss53分支所指的快照(C4,C5)以及它们的公共祖先(C2)做一个简单的三方合并。Git会自行选择最优的祖先作为合并的基础,这是与更加古老的CVS以及SVN(1.5版本以下)的一个很大的区别,这些系统中需要用户自己指定最佳的合并基础。

同样在合并完成之后,可以使用 git branch -d iss53 删除分支。
2.有冲突时候的合并
合并分支有时候没有这么的顺利,有时候会存在冲突。
冲突产生的情况:在两个不同的分支中,对同一个文件的同一个部分进行了修改,就会产生冲突。
例如:上述例子中,如果你在hotfix和iss53分支中都对index.html的同一处位置进行了修改,那么在合并iss53到master分支的时候就会产生冲突,这时候你需要手动的去解决冲突,然后将index.html标记为冲突已解决,最后进行提交。
出现冲突的文件会出现一些如下图所示的标记:
其中在 ======= 的上半部分是HEAD所指向的master分支的内容,在 ======= 的下半部分是iss53分支的内容。你需要自己手动去选择保留 ======= 的上半部分或者下半部分,或者都保留。同时你也需要删除<<<<<<< HEAD:index.html ======= >>>>>>> iss53:index.html 这些特殊标记。
<<<<<<< HEAD:index.html
<div id="footer">contact : email.support@github.com</div>
=======
<div id="footer">
please contact us at support@github.com
</div>
>>>>>>> iss53:index.html
当你自己手动解决了所有的冲突之后,你需要运行 git add <filename> 来将每一个存在冲突的文件标记为冲突已解决的状态,并且暂存这些文件。通常你还需要运行 git status 来确认所有的冲突是否都已经解决了。
最后你可以运行 git commit 来完成合并提交。在提交信息中,通常比较专业的做法是提供详细的信息来描述你是怎么解决这次冲突的,你的理由是什么。好像有个模板可以套用,用的时候可以自行百度。
9.Git分支-分支的创建与合并-02的更多相关文章
- git分支管理之创建与合并分支
在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...
- GIT 分支管理:创建与合并分支、解决合并冲突
分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN. 如果两个平行宇宙互不干扰,那对现在的你也没啥影响.不过,在某个时间点,两个平行宇宙合并 ...
- Git 基础教程 之 创建与合并分支
- 创建与合并分支-git入门教程
在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...
- git创建与合并分支
创建与合并分支 在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分 支,即master分支.HEAD严格来 ...
- [廖雪峰] Git 分支管理(1):创建与合并分支(HEAD、master、dev、指针)
每次提交,Git 都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在 Git 里,这个分支叫主分支,即 master 分支.HEAD 严格来说不是指向提交,而是指向 mas ...
- git 学习笔记 --创建与合并分支
在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...
- Git创建与合并分支,撤销修改
git回滚到指定版本并推送到远程分支(撤销已提交的修改,并已push) git reset --hard <commit ID号> git push -f git回滚到上一个版本并推送到远 ...
- Git----分支管理之创建与合并分支02
在版本回退里,你已经知道 ,每次提交,Git都把它们串i成一条时间线,这条时间线就是一个分支,截至到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支,HEAD严格来说不是指向提交 ...
随机推荐
- JAVA-MyBaits对应XML的两种使用方式
概述 在使用XML写SQL语句的时候,遇到参数传递的两种方式,也就是Mapper里面带@Param注解和不带的情况,容易混淆,对应XML的写法也不相同,使用的时候要注意对照代码比对(备注XML里面的关 ...
- JS,JQ实现模拟暂停FOR循环,间隔几秒后再继续执行
<!DOCTYPE html><head><script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquer ...
- James Munkres Topology: Sec 22 Exer 3
Exercise 22.3 Let \(\pi_1: \mathbb{R} \times \mathbb{R} \rightarrow \mathbb{R}\) be projection on th ...
- C++ this指针
成员函数不能定义 this 形参,而是由编译器隐含地定义.成员函数的函数体可以显式使用 this 指针,但不是必须这么做.如果对类成员的引用没有限定,编译器会将这种引用处理成通过 this 指针的引用 ...
- .net 第一次请求比较慢
为了提高访问速度,也便有了预编译. 关于ASP.NET网站:每个页面都编译成一个.dll文件 用Assembly.GetExecutingAssembly().Location 查看 而ASP.NET ...
- os模块walk方法
1.os.walk import os for root, dirs, files in os.walk(top, topdown=False): for name in files: os.remo ...
- 连接数据库出现java.sql.SQLException: Unknown system variable 'tx_isolation'
问题分析 :mysql-connector-java的版本太低,数据库的版本太高 因此将mysql-connector-java升级到最新版本就解 .或者降低MySQL的版本.我之前用的是8.0版本 ...
- Hibernte
什么是CRM?(了解) CRM(customer relationship management)即客户关系管理,是指企业用CRM技术来管理与客户之间的关系.在不同场合下,CRM可能是一个管理学术语, ...
- python学习笔记(5)
.................................................................................................... ...
- 原生js的联动全选
开发应用中有很多工具可以使用,下面介绍一个原生js写的联动全选思路!!! <!DOCTYPE html> <html lang="en"> <head ...