`
llyzq
  • 浏览: 580028 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

SVN分支与合并学习

阅读更多

转自http://limaoyuan.iteye.com/blog/1026809

 

本文和大家一起讨论一下SVN分支与合并,很多用户都很了解SVN分支与合并了,这里我发表一下个人理解,和大家讨论讨论。首先我们看一下SVN分支与合并的具体步骤: 

1.创建分支的意义 
创建分支的意义,比如我们在一个基础平台上进行开发,每个技术小组负责一个子项目,而基础平台也是有可能会继续更改的,这个时候,如果不创建分支,子项目之间会相互影响,影响最大的就是后期的测试和版本发布,子项目A已经结束,但测试却受到正在进行的子项目B的影响,测试通不过,就别说版本发布了。所以,我们需要从目前的项目(主干trunk)中创建分支(branch),隔离子项目间的相互影响。 

2.svn创建分支原理 
在svn中,创建分支,实际上就是一个版本拷贝(对应copyto...注意:绝不是简单在客户端上copy一个目录,而是svn仓库中copy,文件版本号会增加。),两边做任何修改发生的版本变化,是一套机制。举例:目前主干版本是100,分支版本是101,主干中增加一个文件,版本为102,分支中再增加一个文件,版本就为103了。两边的版本号是一套,不会重复。 

3.svn创建分支的方法 
TortoiseSVN:右键点击工程目录 ->TortoiseSVN->Branch/tag..菜单,FromWCatUrl自动为工程svnurl,比如https: //localhost:8443/svn/fbysss/prj1/trunk,toUrl填写https://localhost:8443/svn /fbysss/prj1/branches/branch1。点OK按钮,分支就创建好了。 
Subclipse:Team->Branch/tag..,跟上面类似. 
SVN命令模式:svncopytrunk_pathbranch_path-m'描述' 
举例:svncopyhttps://localhost:8443/svn/fbysss/prj1/trunk 
https://localhost:8443/svn/fbysss/prj1/branches/branch1-m"第一个分支" 
注意一点:trunk和branch不能互为子目录,否则就乱套了。 

4.SVN分支与合并 

1)从分支合并到主干 
分支开发结束之后,往往需要合并回主干去测试、发布,但分支和主干可能有很多冲突的地方,在合并时经常需要手工解决。 
被操作对象:主干 
From:主干的打出分支时的版本 
To:分支的Head版本(最新版本) 
怎么理解这个From和To呢?似乎跟我们的想当然不太一样:因为我们理解,把分支合并到主干,肯定是From分支,To主干。怎么搞反了呢? 
实际上,Svn认为,我们要合并的,是从主干的某个版本开始,到分支的某个版本结束。两边的版本号实际上是一套系统,不会有重复。我们从TortoiseSVNHelp中也能找到证据: 

   1. viewplaincopytoclipboardprint?  
   2. Ifyouareusingthismethodtomergeafeaturebranchbacktotrunk,youneedto........  
   3. IntheFrom:fieldenterthefullfolderURLofthetrunk.Thismaysoundwrong,butrememberthatthetrunkisthestartpointtowhichyouwanttoaddthebranchchanges.Youmayalsoclick...tobrowsetherepository. 
   4. IntheTo:fieldenterthefullfolderURLofthefeaturebranch.  
   5. Ifyouareusingthismethodtomergeafeaturebranchbacktotrunk,youneedto........  
   6. IntheFrom:fieldenterthefullfolderURLofthetrunk.Thismaysoundwrong,butrememberthatthetrunkisthestartpointtowhichyouwanttoaddthebranchchanges.Youmayalsoclick...tobrowsetherepository. 
   7. IntheTo:fieldenterthefullfolderURLofthefeaturebranch.  

2)从主干合并到分支 
试想这样的情况:一个项目里面,要独立出来一个子项目,需要单独发布版本,用到了基础框架代码,而基础框架在主干中不断修改完善,这就需要从主干合并到分支。 
被操作对象:分支 
From:分支的第一个版本(最旧版本) 
To:主干的Head版本(最新版本) 
相当于从分支的第一个版本开始一直到主干最后一个版本结束合并之后,替换分支。 
实际上,SVN分支与合并,在管理上是有较大的意义不同,但对于svn系统技术层面来讲,二者是平等的,可互为主干和分支。

分享到:
评论

相关推荐

    SVN分支与合并【超详细的图文教程】

    SVN分支的意义: 简单说,分支就是用于区分开发版本与当前发布版本的。  1、 主干负责新功能的开发  2.、分支负责修正当前发布版本的bug(对于可以放入下个发布版本的改进性bug可以直接在主干上开发)  3.、...

    SVN 分支与合并详解

    下面是对SVN分支与合并的详细讲解。 1. SVN分支创建: 在SVN中,创建分支通常是为了进行长期的特性开发或隔离修复工作。你可以通过`svn copy`命令或者在图形界面工具中选择“创建分支”选项来实现。例如,要从...

    SVN分支与合并

    SVN分支与合并,从创建分支到合并分支,步骤图文详解

    Eclipse svn创建分支、合并、切换讲解

    3. 点击 Finish,完成,可以看到项目里出现了分支 merge_v1.0 分支中第 9026 次提交的东西最后提交即可,分支合并主干顺利完成。 四、冲突解决 在合并操作中,可能会出现冲突问题。冲突问题是指在合并过程中,出现...

    SVN分支合并到主干 冲突处理

    本文将详细讲解如何进行SVN分支与主干的合并以及冲突处理,帮助开发者更好地理解和掌握这一核心操作。 ### SVN分支与主干的概念 在SVN中,"分支"和"主干"是两个重要的概念。主干(Trunk)通常代表项目的主要开发线...

    SVN创建、合并与切换分支操作详解

    SVN的目录结构解释与SVN创建分支、合并分支、切换分支的操作详解。

    SVN分支的创建与合并

    SVN 分支的创建与合并 SVN 分支是一种版本控制系统的特性,允许开发者将不同的修改分离出来,放在开发品的一个分割线上。这条线被称为分支。分支经常被用来试验新的特性,而不会对开发有编译错误的干扰。当新的特性...

    SVN使用的分支与合并

    SVN 分支与合并详解 SVN(Subversion)是一款开源的版本控制系统,广泛应用于软件开发、文档管理和其他需要版本控制的领域。在软件开发过程中,SVN 的分支与合并功能是非常重要的,下面我们将详细介绍 SVN 中的分支...

    SVN 拉分支及合并演示

    SVN 拉分支 合并 有详细的SVN拉分支及合并操作

    svn拉分支合并文档

    "svn拉分支合并文档" SVN(Subversion)是一种开放源代码的版本控制系统,相比RCS和CVS,它采用了分支管理系统。SVN的主要特点是支持分布式版本控制,能够对文件和目录进行版本控制。 svn目录结构: * 每个子系统...

    SVN分支的合并和同步

    SVN分支的合并和同步 SVN(Subversion)是一种版本...* 不管是从trunk合并到分支还是最终从分支合并回trunk,在每次合并前最好先update,然后将本地的修改先全部commit,保护好现场,万一合并不理想随时都可以revert

    svn分支合并基本操作

    因此各开发成员需要建立自己的开发分支,并在此分支上进行开发工作,之后各开发成员把分支合并到主干上并形成较为稳定的版本,在后续的工作中各个成员重新从主干上建立新的分支,在此分支上继续开发,并其循环往复...

    SVN版本库分支与合并策略

    列举在开发过程中会出现的开发情况,规范在开发过程中分支的类型,何时分支何时合并

    SVN分支及合并使用文档.doc

    《SVN分支及合并使用详解》 版本控制系统Subversion(SVN)是软件开发中不可或缺的工具,尤其在团队协作中,分支与合并是其核心功能。本文将深入解析SVN的分支创建、管理和合并过程,帮助开发者更好地理解和运用这...

    svn主干与分支互相合并

    新手看看。高手绕道。主要是关于svn主干与分支互相合并的问题

    SVN分支机制和开发规范

    二、 SVN分支简介 1、SVN仓库目录结构Repository 2、 结合eclipse创建分支 3、 结合eclipse创建标记tags 三、 合并主干和分支 1、 主干合并分支 2、 分支合并主干 3、 合并发生冲突 情况1:标记冲突,稍后处理。 ...

    SVN分支与主干代码合并.png

    在信息技术飞速发展的今天,为了加快开发的效率,提升各个部门的联动配合,SVN工具成为了我们必不可少的研发工具。 日益更新的用户需求和不断升级的版本,如何才能做到灵活控制版本,今天我们请到了智博创享web端...

    svn提交代码合并分支.txt

    svn提交代码合并分支.txt

    TortoiseSVN 分支与合并操作

    **TortoiseSVN 分支与合并操作** TortoiseSVN是一款强大的Subversion(SVN)客户端,专为Windows用户设计。它提供了一个图形化的界面,使得版本控制操作更加直观和便捷。在软件开发中,分支管理和合并是至关重要的...

    eclipse中利用svn创建、合并、切换分支

    eclipse中利用svn创建、合并、切换分支

Global site tag (gtag.js) - Google Analytics