冲突的解决原则

不是自己修改的地方就使用主干的。

需要特别注意的是:

分支同步主干时,远端(theirs)是主干,本地(mine/working)的是分支;

分支合入主干时,本地(mine/working)的是主干,远端(theirs)是分支。

二进制文件的冲突解决

对于*.jar *.png 等二进制文件的冲突,如果这些文件与你的业务开发是无关的,直接右键"Resolve"即可。

汉字注释中的"真假李逵"

在执行merge后,会发现代码中有些汉字注释有提示改动了,但内容却仍是一模一样的情况。见图1。

图1. 汉字注释"真假"

出现这种情况的原因是在写汉字注释时不是使用的统一的编码(如:utf-8),就会出现看起来一模一样的注释内容,但SVN仍却显示有改动的提示。这种情况有可能导致编译失败。经查,图4中左边使用的是"utf-8"编码,但右边却使用"gbk"编码。出现这种情况时得及时统一文件编码。

*.prej冲突的解决

该冲突的产生原因未明,解决方法是直接删除该文件即可。

冲突的解决范围

由于手Q是多个工程联合编译的,这里首先要认识一下根目录的概念。

根目录是指能全编App的目录。

进行分支的同步与合入主干时,所有的merge操作都是针对根目录进行操作的。但这两个操作的步骤需要解决冲突的范围是不一样的。

分支同步主干时,解决冲突的范围是根目录下的所有文件及文件夹,然后进行提交。

分支合入主干时,解决冲突的范围一般只需要是主App下面的文件及文件夹。如若其它Library App与你自己开发的业务相关,只要是经过自己修改的,那也在解决冲突的范围内,不在自己业务范围内则不用处理了,节省时间吧。

非常非常重要:冲突解决后的代码复审

分支合入主干后,最头疼的情况是什么?是发现刚合入的代码冲掉了主干原本的代码或把主干已经删除的代码又恢复了,这种情况一发生,那就只能是代码回滚,再来操作一次分支合入。要哭死了!

避免这个失误的出现,只有小心为上,可以这么做。

解决冲突时深入一个一个文件夹逐一解决,解决完每一个文件夹里的所有冲突时,右键该文件夹,点击"SVN Commit",然后逐一查看列出来的被修改的代码文件。一旦发现SVN的比较结果中有出现前后版本差异,但内容却不是自己所开发的业务需要的,此时要慎重再慎重,确认再确认,这种情况一般都是解决冲突时版本管理出错了。需Revert重新解决该文件的冲突。

本文为Sodino所有,转载请注明出处:http://blog.csdn.net/sodino/article/details/17126905

分支合入主干流程

嗯..没图说不清,见下图2吧。

图2. 分支合入主干时序图

图中标题Branch表示分支代码库,checkout版本号为ver.m的代码至本地新建的文件夹branch.working。然后再merge主干代码Ver.A至branch.working,解决完冲突后提交至分支生成新版本ver.n。第一步完成。

第二步首先checkout主干代码Ver.A至本地新建文件夹trunk.working,使用merge操作将分支ver.n合入trunk.working,第二步完成。标识此时trunk.working的临时版本号为Ver.An。。

如果在完成前两步的过程中主干有同学提交了新代码,则需要update至最新代码并解决冲突,这样trunk.working版本为Ver.AnC,解冲突后提交至主干。至此,合入操作完成。

[SVN] 分支同步、合入主干操作分享的更多相关文章

  1. svn 分支整个项目合并主干

    1.首先主干要更新最新版本. 2.找到主干(trunk)点击右键--合并--合并类型选择(合并一个版本范围)点击下一步--合并源选择整个分支项目--将要合并的修改版本范围(选择指定(a)范围)点击下一 ...

  2. Eclipse 中svn 分支,主干 合并与同步:

    Eclipse 中svn的合并与同步: 1.  从主干拉取到分支: 然后一直下一步,到完成就OK了. 2.  从分支代码合并到主干: 2.1.先将本地需要提交更新的代码提交更新到svn分支去 2.2. ...

  3. SVN分支/主干Merge操作小记

    一.前言 说来惭愧,鄙人从事开发多年,使用svn已经好几个年头了,但是却仅限于update.commit.compare之类的操作,最近想到github上学习别人写的NIO源码,顺便去熟悉git的使用 ...

  4. eclipse svn 分支合并到主干

    最近公司产品上线,整个系统架构包含有七八个子系统,并且子系统都是集群部署.所以每次升级维护都要确保尽可能不出问题.因为整个系统刚上线不久,意味着新系统不定期有BUG需修复,但新功能模块也在持续的开发中 ...

  5. eclipse中SVN分支合并到主干

    在项目开发中,需要添加一些新的功能,但是又不想影响到其他开发人员的项目进度,所以决定使用SVN分支进行开发,分支开发完毕后再合并到主干.本文介绍如何在eclipse中合并分支到主干. 1. 要想将分支 ...

  6. 图文:eclipse中SVN分支合并到主干

    在项目开发中,需要添加一些新的功能,但是又不想影响到其他开发人员的项目进度,所以决定使用SVN分支进行开发,分支开发完毕后再合并到主干.本文介绍如何在eclipse中合并分支到主干. 1. 要想将分支 ...

  7. SVN分支/合并操作小记

    一.前言 说来惭愧,鄙人从事开发多年,使用svn已经好几个年头了,但是却仅限于update.commit.compare之类的操作,最近想到github上学习别人写的NIO源码,顺便去熟悉git的使用 ...

  8. SVN分支的创建,合并,与销毁和相关操作

    test是分支和主干所在的文件夹,SVNTest是主干,所有的分支都放在branch里面,192.168.1.101是服务器的地址 创建分支: 把服务器中的主干复制出来到自己的分支上: svn cop ...

  9. 操作实践,git本地分支执行rebase,让主干分支记录更简洁

    声明:迁移自本人CSDN博客https://blog.csdn.net/u013365635 我们平时在写代码的时候,难免会修修改改,如果团队中每个人的代码提交记录都包含着一堆中间过程,是很不利于团队 ...

随机推荐

  1. Solr4.7从数据库导数据

    实际工程应用中,从数据库导出数据创建索引再常见不过了,现在实验一下从数据库导入数据创建索引. 一.版本说明 Solr版本:4.7.0 数据库:sqlserver2005 二.配置步骤 1.  准备的j ...

  2. 转:CSS圆角详解

    CSS3是样式表(style sheet)语言的最新版本,它的一大优点就是支持圆角. 网页设计大师Nicholas Zakas的最新文章,清晰易懂地解释了CSS3圆角的各个方面,非常值得学习.以下就是 ...

  3. setitimer()函数使用

    setitimer()为Linux的API,并非C语言的Standard Library,setitimer()有两个功能,一是指定一段时间后,才执行某个function,二是每间格一段时间就执行某个 ...

  4. jetty插件开发配置

    <plugins> <!-- jetty插件 --> <plugin> <groupId>org.mortbay.jetty</groupId&g ...

  5. 一、Mongo的安装

    注:学习为主,平台为WIN7 32位系统 一.Mongo的安装 1.1 下载 到官方下载地址(http://www.mongodb.org/downloads)去下载所需要的版本 1.2 安装与运行 ...

  6. 创建成功的Python项目

    创建成功的Python项目 前端开发工具技巧介绍—Sublime篇 SEO在网页制作中的应用 观察者模式 使用D3制作图表 英文原文:Create successful Python projects ...

  7. 四大流行的jdbc连接池之C3P0篇

    C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSourc ...

  8. Android开发之SoundPool使用具体解释

    使用SoundPool播放音效 假设应用程序常常播放密集.急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了.由于MediaPlayer存在例如以下缺点: 1)      ...

  9. while和do while习题

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace 练习 { ...

  10. 【linux】arm mm内存管理

    欢迎转载,转载时请保留作者信息,谢谢. 邮箱:tangzhongp@163.com 博客园地址:http://www.cnblogs.com/embedded-tzp Csdn博客地址:http:// ...