冲突解决:

先尝试制造冲突:

首先我:git checkout -b mzy

创建一个mzy的分支

然后在其中修改readme.txt文件,随便加上一点东西。

vim readme.txt   write... wq

然后:

git add readme.txt
git commit -m "mzy分支上修改"

这时我的master分支还是指向上一个版本的,但是我的mzy分支已经迭代了一个版本了。

但是现在如果切换回master分支,并且使用git merge mzy,这时因为master和mzy仍然

只是简单的前后相邻的两个单线性版本,所以直接merge不会有任何问题。


但是我现在要做的是制造冲突!

所以我先git checkout master,首先切换到了master分支

我又vim readme.txt,把其中的内容随便修改了一下。

然后在master分支上:

git add readme.txt
git commit -m "在master主分支上修改提交readme.txt"

现在关系就复杂了,就不是简单的线性关系了,而是有了分叉。

现在再次,在master主分支上试图合并mzy分支:
git merge mzy,发现:

$ git merge mzy
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.

告诉我们,当前分支和我们要合并的mzy分支有冲突,必须手动合并,自动合并失败了!
git status,查看当前git的状态

$ git status
On branch master
You have unmerged paths.
(fix conflicts and run "git commit")
(use "git merge --abort" to abort the merge) Unmerged paths:
(use "git add <file>..." to mark resolution) both modified: readme.txt no changes added to commit (use "git add" and/or "git commit -a")

发现现在提示,在我们尝试合并master分支和mzy分支的时候,因为其中对相同的readme.txt文件有修改所以不能自动合并

提示有unmerged paths,让我们手动去解决它。


然后我们打开 readme.txt,发现其中有:

git 是一个好工具,就是门槛比较高。

<<<<<<< HEAD

这是我在master上add,commit的内容

=======

这是我在mzy上add,commit的内容

>>>>>>> mzy

可以看出git在这种无法自动处理的冲突上,使用了
<<<<<<<

=======

>>>>>>>

进行标识

<<<<<<<HEAD:固定的表示当前HEAD指向的,不一定是master。

=======:用于冲突之间分隔

>>>>>>>:被合并分支名称

内容一定是当前分支在HEAD下,被合并分支在后面。

手动修改这些文件,去掉其中的分隔符号,并且把内容修改成你想要的样子,
再次 git add readme.txt,git commit -m "合并分支mzy,并且解决了冲突"

但是要注意,只有当前分支会产生修改,被合并的分支是不会发生改变的!

现在提示:[master 3b15b8e] conflict fixed 合并成功!


我们可以让日志显示格式改一改,看到其中的合并步骤:
git log --graph --pretty=oneline --abbrev-commit
<

或者直接使用简单的:git log --graph[这样会显示很长]

或者:git log --graph --pretty=oneline

[这样会把全部显示commitId,没有reflog那种简洁]

最好的还是:
git log    --graph      --pretty=oneline   --abbrev-commit

查看日志  分支合并图    一行显示       缩减commitId的长度

>

$ git log --graph --pretty=oneline --abbrev-commit
* 3b15b8e (HEAD -> master) conflict fixed
|\
| * dbee345 (mzy) AND simple
* | b1d6af5 在主分支上进行提交
|/
* fd4ceae 修改了readme.txt文件
* c5687b8 删除test.txt[C
* b71048d 提交test.txt
* 88726c9 提交了readme.txt中的修改
* e4deff9 git change readme.txt add tracks change of files
* 9a3670d add LICENSE to res
* c3e7dc7 加上了GPL
* c17e52f 加上了一些新玩意儿distributed
* 9f6ffb9 第一次提交readme.txt

finish, 冲突解决!

问:

是不是如果没有 git merge mzy,那么status就不会显示冲突?

是的,如果你的分支都在各自工作,没有merge,就算相同的文件中都各自有修改,git status都是不会提醒的,

只有你合并的时候,才会出现冲突,各个分支其实是互不干扰的!

如果,是修改的两个不同的文件还会有冲突吗?但是应该还是有分支的吧?不是线性的?

不会有冲突,是的,还是发散出了分支的,但是不会冲突了,因为修改的是不同的文件!

当我们在master上进行merge分支的时候:

$ git merge mzy

Already up to date.(已经是最新的了。)

直接就提示成功了!

mzy git学习,分支冲突,以及冲突解决(五)的更多相关文章

  1. mzy git学习,分支以及分支合并(四)

    git 鼓励大量使用分支:最后进行master和分支之间的合并 git branch git branch 查看当前有多少分支,并且将当前在使用的分支用*标注出来. [一定要注意git的分支有从属概念 ...

  2. mzy git学习,git推送到远程库(八)

    git在同步到远程库 关于git中多个用户切换的事情: 完全使用账户密码策略连接远程库: 之前一直尝试在本地切换多个用户,发现一直不行,很奇怪?后面发现必须要去win10的凭据管理器删除当前git的凭 ...

  3. 139.00.005 Git学习-分支管理

    @(139 - Environment Settings | 环境配置) 一.Why? 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交, ...

  4. mzy git学习,初识git(一)

    GIT学习 git工作区.暂存区.本地库.远程库 工作区:实际上我们工作的地方,进行写代码或者文件的地方. 暂存区:我们执行了git add 操作之后,就会被提交到暂存区. 本地库:其实最后我们需要执 ...

  5. 【学习总结】Git学习-参考廖雪峰老师教程五-远程仓库

    学习总结之Git学习-总 目录: 一.Git简介 二.安装Git 三.创建版本库 四.时光机穿梭 五.远程仓库 六.分支管理 七.标签管理 八.使用GitHub 九.使用码云 十.自定义Git 期末总 ...

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

    人生不如意之事十有八九,合并分支往往也不是一帆风顺的. 我们准备新的分支newbranch. LV@LV-PC MINGW32 /c/gitskill (master)$ git checkout - ...

  7. mzy git学习, 保留现场,恢复现场,以及bug分支处理(七)

    git stash 在git中有时候我们工作做了一半,但是有点急事需要离开一段时间,或者现在需要切换到另一个分支下,去维护和修改一些其它的东西,但是我们现在的工作还没有完成,提交上去的话,并不是完整的 ...

  8. mzy git学习,git协同开发忽略文档配置以及一些杂点(九)

    回忆一个电脑多账户问题 之前也说了,如果使用ssh登陆的话,一个电脑就只能登陆一个账号了,不像通过凭据可以切换(但是其实也可以每次去生成新的公钥和私钥,只要你不嫌麻烦) 再次补充: ssh-keyge ...

  9. mzy git学习,禁用Fast forward的普通合并(六)

    git merge --no-ff -m "msg" x-branch:禁用Fast forward的普通合并 通常,合并分支时,如果可能,Git会用Fast forward模式, ...

随机推荐

  1. LeetCode 895. Maximum Frequency Stack

    题目链接:https://leetcode.com/problems/maximum-frequency-stack/ 题意:实现一种数据结构FreqStack,FreqStack需要实现两个功能: ...

  2. element ui table表头动态筛选条件

    本文主要实现:根据el-table表格数据自动生成表头筛选条件的方法,可根据表格数据动态调整. el-table表格的表头增加筛选功能,大家平时都是怎么实现的呢?先看看官方文档的例子: 1 <t ...

  3. 聊聊 Spring AOP 的不为常知的“秘事”

    Spring AOP 在我们日常开发中扮演了一个非常重要的角色,对于如何使用 AOP 相信很多人已经不陌生,但其中有一些点却容易被我们忽视,本节我们结合一些"不为常知"的问题展开讨 ...

  4. Mybatis order by 动态传参出现的一个小bug

    大家好,我是老三,一个平平无奇的CRUD仔. 今天,我正在愉快地CRUD,突然发现出现一个Bug,我们来看看是怎么回事吧! 问题由来 一个简单的需求,要求把和当前用户相关的数据置顶展示. 这里,我用了 ...

  5. P3312 数表

    P3312 数表 题意 求出 \[\sum_{i=1}^n\sum_{j=1}^m\sigma(\gcd(i,j))[\sigma(\gcd(i,j))\le a] \] 其中 \(\sigma\) ...

  6. SSM框架中,利用ajax,jQuery,json动态刷新局部页面,实现用户名查重提示

    1.在applicationContext.xml配置json文件 2.jsp页面 3.js语句 js语句在script标签中使用, 4.控制层 5.逻辑处理层 6.Dao层方法 7.Mapping层 ...

  7. python使用正则+jsonpath处理接口依赖

    1.接口2的入参值依赖接口1的响应结果,如接口2的入参ids需要拿到接口1响应结果的id字段值,测试用例写在excel中,参数:{"ids":"${$..id}$&quo ...

  8. 什么是ETL--ETL定义、过程和工具选型思路

    ETL代表"提取.转换和加载".ETL 过程在数据集成策略中起着关键作用.ETL允许企业从多个来源收集数据并将其整合到一个集中的位置.ETL还使不同类型的数据可以协同工作. 概述 ...

  9. 初学MyBatis(踩坑)Error querying database. Cause: java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long

    最近在学习Mybatis,代码全部根据教程写好了,一运行结果报了一个错误,主要错误内容: Caused by: org.apache.ibatis.exceptions.PersistenceExce ...

  10. 使用C#winform编写渗透测试工具--敏感目录扫描

    使用C#winform编写渗透测试工具--敏感目录扫描 由于之前在做渗透测试的时候,发现使用的工具较多,切换起来较麻烦,便萌生了开发一个包含各种渗透测试工具的小程序,包括敏感目录扫描.端口查询.子域名 ...