[Git] 018 冲突在所难免,需要巧妙化解
0. 回顾
- [Git] 005 初识 Git 与 GitHub 之分支 中“4.2 情形二”的 9 提及了“解决冲突”
- 当时没有展开,这回详谈
- 我这回反其道而行,先讲一下制造冲突失败的案例
1. 没有条件,创造条件(第一创)
- 条件创造失败案例
1.1 新建一条分支,并切入其中

1.2 打开 "note_01.txt" 并修改

1.3 保存、添加、提交、切换


- 上图有个提示
Your branch is ahead of 'origin/master' by 1 commit.- 当前分支 (master) 比远程仓库多一次 "commit"
- 目前的情况

1.4 合并

合并结果分析
- "conflict" 分支的内容覆盖了之前的内容
- 并没有产生冲突
- 倒是和 [Git] 017 加一条分支,享双倍快乐 的 "2.3" 一致
2. 继续创造条件(第二创)
- 条件创造失败案例
2.1 目前的情况

2.2 修改 "master" 分支的 "note_01.txt"
- 这一步是对“第一创”的改进

2.3 添加
- 这一步是对“第一创”的改进

2.4 切到 "conflict" 分支,并修改 "note_01.txt"


2.5 添加

2.6 切回 "master" 并合并

合并结果分析
- 并没有进行合并操作,原因:上回已经合并过了
- 并没有产生冲突
- [Git] 008 status 与 commit 命令的补充 的 "2.4" 是没有 "add" 之过
- 这回是没有 "commit" 之过
3. 事不过三(第三创)
- 成功创造“冲突”
3.1 目前的情况
- "2.1" 示意图适用于现在的情况
- 仓库没有变化,只是工作区与暂存区的内容变动了
3.2 切到 "conflict" 分支

- 从上方红框中可以看出工作区的 "note_01.txt" 有变动
3.3 修改 "conflict" 分支下的 "note_01.txt"

- 记得保存
3.4 添加并提交

3.5 切到 "master" 分支

3.6 修改 "master" 分支下的 "note_01.txt"

- 记得保存
3.7 添加并提交

3.8 合并

- 产生冲突
- "note_01.txt" 存在冲突
- 必须手动解决冲突后再提交
- 此时可以用
git status查看一下

- 此时的 "note_01.txt"

4. 解决冲突
4.1 “ 定稿” "note_01.txt"

4.2 再次提交

4.3 目前的情况

4.4 "log" 命令的补充
git log --oneline --graph

[Git] 018 冲突在所难免,需要巧妙化解的更多相关文章
- 转:git合并冲突解决方法
git合并冲突解决方法 1.git merge冲突了,根据提示找到冲突的文件,解决冲突 如果文件有冲突,那么会有类似的标记 2.修改完之后,执行git add 冲突文件名 3.git commit注意 ...
- git合并冲突解决方法
1.git merge冲突了,根据提示找到冲突的文件,解决冲突 如果文件有冲突,那么会有类似的标记 2.修改完之后,执行git add 冲突文件名 3.git commit 注意:没有-m选项 进去类 ...
- git 出现冲突时的解决办法
<一> 二者兼得最麻烦 1, 出现冲突一般出现在群体开发两个及以上开发者同时修改同一个文件时 2, 具体表现为 git pull , git push 和 git commit 命令执行失 ...
- Git二进制文件冲突解决
Git二进制文件冲突解决 在我们合并分支的时候,如果两个分支都进行了修改那么就会产生合并冲突.对于非二进制文件的冲突解决,git会给出冲突的位置我们可以手动修改然后再commit.但是对于非二进制文件 ...
- 「GIT SourceTree冲突」解决方案
现在程序猿标配GIT作为代码管理,但是从SVN到GIT学习中,其中GIT的冲突是一个难点,常常会导致Push不上去,Pull不下来,很尴尬的地步,还不知道自己写的代码被覆盖没,废话不多说,直接上干货! ...
- git 代码冲突处理
在使用git pull代码时,经常会碰到有冲突的情况,提示如下信息: error: Your local changes to 'c/environ.c' would be overwritten b ...
- git 解决冲突问题
问题描述: 一般来说,只要多人提交同一仓库,必然会有冲突的发生. Git解决 利用git解决冲突很简单,最常规的方法莫过于工作之前先更新整个project,完成之后及时提交.然而尽管这样做,也难免有人 ...
- git 解冲突
如果希望保留生产服务器上所做的改动,仅仅并入新配置项, 处理方法如下: git stash git pull git stash pop 然后可以使用Git diff -w +文件名 来确认代码自动合 ...
- git解决冲突方式
Git解决冲突 安装beyond compare 4 2.配置git对比工具 #difftool 配置 git config --global diff.tool bc4 git config --g ...
随机推荐
- 5G技术被夸大?专家来测试一下
像大多数新技术一样,5G也带来了大量媒体宣传.这种炒作中有些伴随着事实的严重扭曲和5G技术实际功能的放大.但是,有一个普遍共识的说法是5G将实现“极速”,换句话说,与前几代产品相比,带宽要高得多. 这 ...
- scikit-plot
安装说明 安装Scikit-plot非常简单,直接用命令: pip install scikit-plot 即可完成安装. 仓库地址: https://github.com/reiinakano/sc ...
- windows上部署hadoop(单机版)
在window系统开发程序时,远程linux服务器上的hadoop速度很慢,影响开发效率,能不能在本地搭建hadoop环境的?答案肯定的,且看下文如何在window上部署hadoop: (源文地址:h ...
- 泛型(三)模拟commons-dbutils
最近在复习泛型的知识,想起以前使用commons-dbutils的时候,觉得这个工具太厉害了.所以,试着自己瞎写看能不能模拟commons-dbutils的功能. 1.commons-dbutils的 ...
- Jackson和fastjson简单用法及性能对比
背景: Java处理JSON数据有三个比较流行的类库FastJSON.Gson和Jackson.fastjson是阿里做的国有开源Java工具包,jackson是spring mvc内置的json转换 ...
- 【深入理解CLR】2:细谈值类型的装箱和拆箱
装箱 总所周知,值类型是比引用类型更“轻型”的一种类型,因为它们不作为对象在托管堆中分配,不会被垃圾回收,也不通过指针来引用.但在许多情况下,都需要获取对值类型的一个实例的引用.例如,假定要创建一个A ...
- Integer类源码浅析
1.首先Integer提供了两类工具类,包括把一个int类型转成二进等, 其实执行转换算法只有一个方法: public static String toString(int i, int radix) ...
- 用JQuery获取事件源怎么写
$(".btn").click(function(e){ // e 就是事件对象 e.target; // 事件的目标 dom e.currentTarget; // 事件处理程序 ...
- Mybatis 一对多 关联查询查询
一对多 与 一对一 查询有许多相似之处. 最主要的区别是 查询结果是list,与之对应的标签为collection. 班级和学生,一个班有多个学生,而每个学生只能属于一个班. 此时班级编号作为学生表的 ...
- 第五周课程总结&试验报告
this和super的区别 区别点 this super 属性访问 访问同类中的属性,如果本类没有此属性则从父类中继续查找 访问父类中的属性 方法 访问本类中的方法,如果本类中没有此方法,则从父类中继 ...