[置顶] 【Git入门之九】解决冲突
原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12309531
1.多人协作冲突
如果多人同时修改了同一个文件,那会出现什么样的结果呢?我们试着这么做。
(1)修改jackygit2
在jackygit2中修改jackydata01,提交修改并推送到远程仓库(这里使用本地远程仓库)。正常,没问题。
- #切换到jackygit2本地库,这是远程仓库那节建立的,从本地远程仓库克隆而来
- $ cd ../jackygit2
- #修改jackygit2/Jackydata01
- $ echo "It's modified in jackygit2" > jackydata01
- #提交jackygit2的修改
- $ git commit -a -m "jackygit2 modify"
- [master 15a6406] jackygit2 modify
- 1 file changed, 1 insertion(+), 1 deletion(-)
- #推送到远程仓库origin
- $ git push origin
- Counting objects: 5, done.
- Delta compression using up to 2 threads.
- Compressing objects: 100% (2/2), done.
- Writing objects: 100% (3/3), 283 bytes | 0 bytes/s, done.
- Total 3 (delta 1), reused 0 (delta 0)
- To d:/jackygit2/../remote-jackygit.git
- c0449de..15a6406 master -> master
(2)修改jackygit
切换到jackygit仓库,同样修改jackydata01,提交修改并推送到远程仓库。这时候就出错了,提示有人改过这个文件了。推送不成功。
- #切换到jackygit
- $ cd ../jackygit
- #修改jackygit/Jackydata01
- $ echo "It's modified in jackygit" >jackydata01
- #提交jackygit的修改
- $ git commit -a -m "jackygit modify"
- [master 9ab7206] jackygit modify
- 1 file changed, 1 insertion(+), 1 deletion(-)
- 推送到远程仓库testremote,这个仓库和上面的origin是同一个远程仓库
- $ git push testremote
- To ../remote-jackygit.git
- ! [rejected] master -> master (fetch first)
- error: failed to push some refs to '../remote-jackygit.git'
- hint: Updates were rejected because the remote contains work that you do
- hint: not have locally. This is usually caused by another repository pushing
- hint: to the same ref. You may want to first integrate the remote changes
- hint: (e.g., 'git pull ...') before pushing again.
- hint: See the 'Note about fast-forwards' in 'git push --help' for details.
(3)抓取远程仓库内容
抓取远程仓库中的文件,这里需要指定分支。
- #抓取远程仓库中的文件,需要指定分支
- $ git pull testremote master
- From ../remote-jackygit
- * branch master -> FETCH_HEAD
- Auto-merging Jackydata01
- CONFLICT (content): Merge conflict in Jackydata01
- Automatic merge failed; fix conflicts and then commit the result.
(4)查看冲突文件内容
冲突用<<<<<< ====== >>>>>>隔开冲突代码,上面的是当前修改内容,下面的则是别人修改的内容。
- #输出当前jackydata01内容
- $ cat jackydata01
- <<<<<<< HEAD
- It's modified in jackygit
- =======
- It's modified in jackygit2
- >>>>>>> 15a6406ed7f889bab7e812f9e6bedb6e78431232
(5)解决冲突
修改冲突内容,重新提交,推送。
- #修改Jackydata01产生的冲突
- $ echo "there is no conflict now" > jackydata01
- #提交修改冲突后文件
- $ git commit -a -m "there is no confilct now"
- [master ac2846f] there is no confilct now
- #推送到远程仓库testremote
- $ git push testremote
- Counting objects: 10, done.
- Delta compression using up to 2 threads.
- Compressing objects: 100% (4/4), done.
- Writing objects: 100% (6/6), 567 bytes | 0 bytes/s, done.
- Total 6 (delta 2), reused 0 (delta 0)
- To ../remote-jackygit.git
- 15a6406..ac2846f master -> master
2.分支合并冲突
这种情况和多人协作冲突处理办法是相似的。在这里也模拟一下。
(1)创建分支并修改内容
- #创建并跳转到分支br
- $ git checkout -b br
- Switched to a new branch 'br'
- #修改br分支中的Jackydata01
- $ echo "It's modified in br" > jackydata01
- #提交br分支中的修改
- $ git commit -a -m "br modify"
- [br 32c8755] br modify
- 1 file changed, 1 insertion(+), 1 deletion(-)
(2)跳转到主分支,同样进行内容修改
- #跳转到master分支
- $ git checkout master
- Switched to branch 'master'
- #修改master分支中的jackydata01
- $ echo "It's modified in master" > jackydata01
- #提交master分支中的修改
- $ git commit -a -m "master modify"
- [master ed84e67] master modify
- 1 file changed, 1 insertion(+), 1 deletion(-)
(3)合并分支
- #合并br到主分支上
- $ git merge br
- Auto-merging Jackydata01
- CONFLICT (content): Merge conflict in Jackydata01
- Automatic merge failed; fix conflicts and then commit the result.
(4)显示冲突文件内容,冲突隔开方式如上所述
- #显示br中Jackydata01内容
- $ cat jackydata01
- <<<<<<< HEAD
- It's modified in master
- =======
- It's modified in br
- >>>>>>> br
(5)解决冲突,重新提交
- 修改Jackydata01产生的冲突
- $ echo "It's no conflict now" > jackydata01
- #提交修改冲突后文件
- $ git commit -a -m "It's no conflict now"
- [master eb073a6] It's no conflict now
(6)删除无效分支
- #删除br分支
- $ git branch -d br
- Deleted branch br (was 32c8755).
[置顶] 【Git入门之九】解决冲突的更多相关文章
- Git命令行下解决冲突
使用Git时,在pull.merge.rebase的过程中,经常会遇到conflict的情况. 遇到conflict时,以上处理过程会终端,并且命令行中显示(xxx|MERGING)的状态(Windo ...
- git分支管理之解决冲突
人生不如意之事十之八九,合并分支往往也不是一帆风顺的. 准备新的feature1分支,继续我们的新分支开发: $ git checkout -b feature1 Switched to a new ...
- git合并分支与解决冲突
前提: 当前开发的分支为feature/20161129_317606_algoplatform_1,由于feature/20161130_322574_tmstools_1分支有新内容,所以准备将f ...
- [置顶]
Git学习总结(1)——Git使用详细教程
一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以 ...
- Git应用之eclipse解决冲突代码
最近上班公司框架换成了微服务下面是eclipse 对代码进行管理 1.冲突代码 如果两个人在一个项目上同一文件上更改代码就会出现冲突现象 先用NewFile.jsp 文件做演示 打开eclipse从 ...
- git cherry-pick 命令,解决冲突后没有 commit 变更,再次pull 时出错
Git : You have not concluded your cherry-pick (CHERRY_PICK_HEAD exists). 解决方法:(1)使用git status 命令查看当前 ...
- [置顶] JUnit入门教程(二)
一:介绍 接着上次的课程,今天我们学习JUnit4的新特性 assertThat()方法,这种方式和其余的assert方法比起来,更加接进英语. 二:分析API API中的例子: 参数 T Actua ...
- [置顶]
Git 配置SSH简单玩法?
> 第一步下载git点击直接下载 他会检测您的系统当前是64bit还是32bit安装过程不再啰嗦反正就是Next Next Next Finish 第二步这里你可以下载TortoiseGit点击 ...
- Git入门指南九:远程仓库的使用【转】
转自:http://blog.csdn.net/wirelessqa/article/details/20152651 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 十三 ...
随机推荐
- python实现登录函数,比较简单
一个简单的python实现登录以及修改密码的函数 #密码错误3次,锁定登录: password_list = ['] def account_login(): Tries = 3 while Trie ...
- Hql 执行CRUD
//新增] @Test public void add(){ config = new Configuration(); sessionfactory = config.configure(" ...
- (转)织梦dedecms后台发布文章提示“标题不能为空”
问题症状:V5.7登录后台后,发布英文标题没问题,发布中文会提示“标题不能为空”. 问题根源:htmlspecialchars在php5.4默认为utf8编码,gbk编码字符串经 htmlspecia ...
- 『重构--改善既有代码的设计』读书笔记----Remove Assignments to Parameters
C++存在按值传递和按引用传递两种传递方式,Java严格按照按值传递这种方式来进行.以按值传递方式的角度来说,如果你 int test(int a) { ) { a = 1; } return a; ...
- JS定义对象方法?
第一种:构造函数形式 把参数作为构造函数的参数传递,这样对于对象的初始化更灵活一点 <script language="javascript"><!-- /** ...
- DIV隐藏与重显
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- gdb调试memcached
1.memcached安装前,要安装libevent 2.memcached在configure中 加上 CPPFLAGS='-ggdb3'选项 例如 本机 ./configure -prefix ...
- Python自动化运维之18、Python操作 MySQL、pymysql、SQLAchemy
一.MySQL 1.概述 什么是数据库 ? 答:数据的仓库,和Excel表中的行和列是差不多的,只是有各种约束和不同数据类型的表格 什么是 MySQL.Oracle.SQLite.Access.MS ...
- css阴影
文字阴影:text-shadow:[颜色 x轴 y轴 模糊半径],[颜色 x轴 y轴 模糊半径]... 区域阴影:box-shadow:[颜色 x轴 y轴 模糊半径],[颜色 x轴 y轴 模糊半径]. ...
- SQL SERVER 数据库邮件配置
1.简单了解数据库邮件的概念和使用的传输协议及系统体系: 数据库邮件是从 SQL Server 数据库引擎中发送电子邮件的企业解决方案.通过使用数据库邮件,数据库应用程序可以向用户发送电子邮件.邮件中 ...