当前位置: 首页 > news >正文

Git合并分支出现的冲突解决

人生不如意之事十有八九,合并分支往往也不是一帆风顺的。

我们准备新的分支newbranch.

LV@LV-PC MINGW32 /c/gitskill (master)
$ git checkout -b newbranch
Switched to a new branch 'newbranch'

修改readme.txt,在最后一行添加:

$ cat readme.txt
master分支内容
添加dev分支内容
分支合并测试

在分支newbranch上提交:

LV@LV-PC MINGW32 /c/gitskill (newbranch)
$ git add readme.txt

LV@LV-PC MINGW32 /c/gitskill (newbranch)
$ git commit -m "newbranch first commit"
[newbranch cccee34] newbranch first commit
1 file changed, 2 insertions(+), 1 deletion(-)

 

切换到master分支上:

$ git checkout master
Switched to branch 'master'
Your branch is ahead of 'origin/master' by 2 commits.
(use "git push" to publish your local commits)

 

在master分支上把readme.txt文件的最后一行添加:

master分支上的合并测试内容

添加,提交

LV@LV-PC MINGW32 /c/gitskill (master)
$ git add readme.txt

LV@LV-PC MINGW32 /c/gitskill (master)
$ git commit -m "master branch merge test"
[master 4bb4c5a] master branch merge test
1 file changed, 2 insertions(+), 1 deletion(-)

这种情况下,自动合并会出现冲突:

LV@LV-PC MINGW32 /c/gitskill (master)
$ git merge newbranch
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.

我们直接查看合并后的readme.txt文件内容:

$ cat readme.txt
master分支内容
添加dev分支内容
<<<<<<< HEAD
master分支上的合并测试内容
=======
分支合并测试
>>>>>>> newbranch

Git会用<<<<<<<,=======,>>>>>>>标记不同分支的内容,我们修改一下后保存

master分支内容
添加dev分支内容
master分支上的合并测试内容
分支合并测试

然后添加,提交:

LV@LV-PC MINGW32 /c/gitskill (master|MERGING)
$ git add readme.txt

LV@LV-PC MINGW32 /c/gitskill (master|MERGING)
$ git commit -m "branch merge"
[master f3d8f1e] branch merge

用带参数的git log也可以看到分支的合并情况:

LV@LV-PC MINGW32 /c/gitskill (master)
$ git log --graph --pretty=oneline --abbrev-commit
* f3d8f1e branch merge
|\
| * cccee34 newbranch first commit
* | 4bb4c5a master branch merge test
|/
* 0d0bbca dev first commit
* d5aea29 master first commit
* 023ee21 Initial commit

现在,删除newbranch分支:

LV@LV-PC MINGW32 /c/gitskill (master)
$ git branch -d newbranch
Deleted branch newbranch (was cccee34).

LV@LV-PC MINGW32 /c/gitskill (master)
$ git branch
* master

小结:当Git无法自动合并分支时,就必须首先解决冲突,解决冲突后,再提交,合并完成

可以用$ git log --graph 命令可以看到分支合并图。

转载于:https://www.cnblogs.com/LvLoveYuForever/p/5523774.html

相关文章:

  • Js事件大全
  • 分布式入门之5:paxos
  • UIScrollView的使用
  • Python学习路程day17
  • python 学习笔记十七 django深入学习二 form,models
  • 深入介绍信号和槽
  • windows下配置python库
  • 个人工作总结03(第二次冲刺)
  • Centos7下Rinetd安装与应用
  • Python3 捕捉异常
  • GCD 和Timer
  • iOS开发UI篇—使用xib自定义UItableviewcell实现一个简单的团购应用界面布局
  • 如何设置电脑的固定IP地址
  • 优质博士的养成之道——对话2015微软学者奖学金获得者
  • 小凡带你搭建本地的光盘yum源
  • [ 一起学React系列 -- 8 ] React中的文件上传
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • 【笔记】你不知道的JS读书笔记——Promise
  • 5分钟即可掌握的前端高效利器:JavaScript 策略模式
  • Akka系列(七):Actor持久化之Akka persistence
  • Apache的基本使用
  • JavaScript设计模式系列一:工厂模式
  • Linux链接文件
  • Perseus-BERT——业内性能极致优化的BERT训练方案
  • Python 使用 Tornado 框架实现 WebHook 自动部署 Git 项目
  • React16时代,该用什么姿势写 React ?
  • Terraform入门 - 3. 变更基础设施
  • Vue源码解析(二)Vue的双向绑定讲解及实现
  • XML已死 ?
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 第十八天-企业应用架构模式-基本模式
  • 高程读书笔记 第六章 面向对象程序设计
  • 每天10道Java面试题,跟我走,offer有!
  • 如何进阶一名有竞争力的程序员?
  • 如何正确配置 Ubuntu 14.04 服务器?
  • 算法---两个栈实现一个队列
  • 一份游戏开发学习路线
  • 如何用纯 CSS 创作一个货车 loader
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • #大学#套接字
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • $con= MySQL有关填空题_2015年计算机二级考试《MySQL》提高练习题(10)
  • (0)Nginx 功能特性
  • (1)常见O(n^2)排序算法解析
  • (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)...
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (html5)在移动端input输入搜索项后 输入法下面为什么不想百度那样出现前往? 而我的出现的是换行...
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (笔记)Kotlin——Android封装ViewBinding之二 优化
  • (每日持续更新)jdk api之FileReader基础、应用、实战
  • (免费领源码)Java#ssm#MySQL 创意商城03663-计算机毕业设计项目选题推荐
  • (十三)Java springcloud B2B2C o2o多用户商城 springcloud架构 - SSO单点登录之OAuth2.0 根据token获取用户信息(4)...
  • (原創) 人會胖會瘦,都是自我要求的結果 (日記)
  • (转)Scala的“=”符号简介