svnsvn 主干 分支 标签和标签的区别

Git 和 SVN 之间的五个基本区别 - 文章 - 伯乐在线
& Git 和 SVN 之间的五个基本区别
英文原文:,编译:
如果你在读这篇文章,说明你跟大多数开发者一样对感兴趣,如果你还没有机会来试一试GIT,我想现在你就要了解它了。
不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等。如果你是一个具有使用SVN背景的人,你需要做一定的思想转换,来适应GIT提供的一些概念和特征。所以,这篇文章的主要目的就是通过介绍GIT能做什么、它和在深层次上究竟有什么不同来帮助你认识它。
那好,这就开始吧…
1.GIT是分布式的,SVN不是:
这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。如果你能理解这个概念,那么你就已经上手一半了。需要做一点声明,GIT并不是目前第一个或唯一的分布式版本控制系统。还有一些系统,例如, 等,也是运行在分布式模式上的。但GIT在这方面做的更好,而且有更多强大的功能特征。
GIT跟SVN一样有自己的集中式版本库或服务器。但,GIT更倾向于被使用于分布式模式,也就是每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库。可以这样说,如果你被困在一个不能连接网络的地方时,就像在飞机上,地下室,电梯里等,你仍然能够提交文件,查看历史版本记录,创建项目分支,等。对一些人来说,这好像没多大用处,但当你突然遇到没有网络的环境时,这个将解决你的大麻烦。
同样,这种分布式的操作模式对于开源软件社区的开发来说也是个巨大的恩赐,你不必再像以前那样做出补丁包,通过email方式发送出去,你只需要创建一个分支,向项目团队发送一个推请求。这能让你的代码保持最新,而且不会在传输过程中丢失。就是一个这样的优秀案例。
有些谣言传出来说subversion将来的版本也会基于分布式模式。但至少目前还看不出来。
2.GIT把内容按元数据方式存储,而SVN是按文件:
所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。如果你把.git目录的体积大小跟.svn比较,你会发现它们差距很大。因为,.git目录是处于你的机器上的一个克隆版的版本库,它拥有中心版本库上所有的东西,例如标签,分支,版本记录等。
3.GIT分支和SVN的分支不同:
分支在SVN中一点不特别,就是版本库中的另外的一个目录。如果你想知道是否合并了一个分支,你需要手工运行像这样的命令,来确认代码是否被合并。感谢Ben同学指出这个特征。所以,经常会发生有些分支被遗漏的情况。
然而,处理GIT的分支却是相当的简单和有趣。你可以从同一个工作目录下快速的在几个分支间切换。你很容易发现未被合并的分支,你能简单而快捷的合并这些文件。
4.GIT没有一个全局的版本号,而SVN有:
目前为止这是跟SVN相比GIT缺少的最大的一个特征。你也知道,SVN的版本号实际是任何一个相应时间的源代码快照。我认为它是从CVS进化到SVN的最大的一个突破。因为GIT和SVN从概念上就不同,我不知道GIT里是什么特征与之对应。如果你有任何的线索,请在评论里奉献出来与大家共享。
更新:有些读者指出,我们可以使用GIT的SHA-1来唯一的标识一个代码快照。这个并不能完全的代替SVN里容易阅读的数字版本号。但,用途应该是相同的。
5.GIT的内容完整性要优于SVN:
GIT的内容存储使用的是哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。这里有一个很好的关于GIT内容完整性的讨论 -
GIT和SVN之间只有这五处不同吗?当然不是。我想这5个只是“最基本的”和“最吸引人”的,我只想到这5点。如果你发现有比这5点更有趣的,请共享出来,欢迎。
可能感兴趣的话题
关于伯乐在线博客
在这个信息爆炸的时代,人们已然被大量、快速并且简短的信息所包围。然而,我们相信:过多“快餐”式的阅读只会令人“虚胖”,缺乏实质的内涵。伯乐在线内容团队正试图以我们微薄的力量,把优秀的原创文章和译文分享给读者,为“快餐”添加一些“营养”元素。
新浪微博:
推荐微信号
(加好友请注明来意)
– 好的话题、有启发的回复、值得信赖的圈子
– 分享和发现有价值的内容与观点
– 为IT单身男女服务的征婚传播平台
– 优秀的工具资源导航
– 翻译传播优秀的外文文章
– 国内外的精选文章
– UI,网页,交互和用户体验
– 专注iOS技术分享
– 专注Android技术分享
– JavaScript, HTML5, CSS
– 专注Java技术分享
– 专注Python技术分享
& 2017 伯乐在线tortoisesvn创建分支branch和标签tag_中华文本库
SVN 主干(trunk)、分支(branch )、标记(tag) 在 ...一阶段的代码的 状态,那么你就需要给代码打上标签...TortoiseSVN使用教程[多... 22页 1下载券
SVN客户...
TortoiseSVN 常规功能介绍 TortoiseSVN 是最常用的 ...3.2 创建分支/ Branch/tag TAG 使得系统目前的...对于文件级的标签,虽然也可以通过 tags 操作,但效果...
这样的布局是为了更清晰的区别主线、分支和标签三者的...的主线目录(trunk)上,右键点击然后选择“Branch/tag...在分支的根目录上右键点击,选择“TortoiseSVN?Merge...
(主线)目录,另外还有 branch(分支)和 tags(标签)...的主线目录(trunk)上,右键点击然后选择“Branch/tag...不知道如何处理 Subversion 客户端,例如 TortoiseSVN...
TortoiseSVN 日常操作指南_IT/计算机_专业资料。...16.1. 创建分支或标记 Creating a Branch or Tag...标签副本.假如一个仓库只保存一个项目,经常会创建...
在本地主干工作副本上创建分支:命令: TortoiseSVN-&分支/标记,URL中输入分支在...project/branch/branch_1,此时版本库 中建立该分支的文件夹,且分支里的内容是...
branch/0.0.1,那么 0.0.1 你可以不用创建,但是/branch 你要先创建好(会...因为 分支和标签是普通的目录,只要你愿意,TortoiseSVN 可以将它们移动或重命名。...
添加的文件或者目录拷贝到 WC 下, 然后在该文件或目录上单击右键,TortoiseSVN-...分支与标签的区别: 在实现上,branch 和 tag,对于 svn 都是使用 copy 实现的...
产品定制的版本,会增加维护成本) tags:表示标签存放...三、合并分支选择右键菜单 TortoiseSVN → 合并......如果要将 MyBranch 的修改合并到 trunk,应该选择 ...
下面我将step by step地演示如何一次完全的branching和merging, 包含创建分支、...branch 在/trunk/MyProject目次上右键,依次选择&TortoiseSVN& -& &Branch/tag....最近在写《IOS性能调优系列》,今天偷个懒,写写SVN与TortoiseSVN实战的第二篇,标签与分支。
第一篇详见《》
SVN与TortoiseSVN实战系列中很多知识点来源于《版本控制之道》这本书,我写的内容主要结合了TortoiseSVN工具,更多侧重于实际操作。
很多项目人员没有正确运用SVN,仅仅作为源代码的团队共享来用,而没有充分利用标签、分支这些强大的特性。
要正确使用SVN的标签和分支特性,就要先建立起合理的项目仓库结构。
正确的SVN项目仓库结构
很多项目人员往往在创建项目仓库以后,直接将整个项目的源代码提交到仓库的根目录,这往往是由于对SVN没有系统的了解。
引用书里的图片,正确的项目仓库目录结构如下图:
在根目录下首先建立三个目录:
1、trunk:又称为主干,这个子目录才是应该将项目源代码提交到的位置。
trunk目录代表着开发的主线,大部分的开发工作涉及到的更新、提交都在这个目录里,就跟&原始&的SVN使用一样。
2、branches:这个目录就是分支目录,所有新建的分支都应放在这个目录。
每一个branches下的分支代表了一条并行的开发过程,如果不明白可以继续往后看。
3、tags:这个目录是标签目录,所有建立的标签都应放在tags目录下。
每一个tags下的标签代表了一个项目的时间节点,或者说是事件、里程碑。
这三个目录之所以如此命名,完全是约定俗成,而非SVN规定。
什么是分支?
分支的基本概念:一条基于另外一条开发线存在的分支,并共享在分离之前的日志,一个分支就象一个拷贝的存在,并从那里离开,并具有自己的历史。
没有找到关于分支很简洁的解释,我的解释是分支相当于对于开发中的主干进行了复制,从此在分支上后续的所有操作与主干上的所有操作互不影响。
使用分支前:
你开发的IOS App已经测试完毕,提交到APPStore审核,在APPStore审核过程中你可能又开发了些功能但还没通过测试,这时APPStore把你的应用退回了,可能是你的Welcome图片不合格需要换一下,很简单的修改可能完全不需要经过测试流程,但这时你只有两种选择:
1、把代码回滚到提交时的状态,修改后提交;
2、把手头的功能开发完成,经过完整的测试、发布流程提交。
合理使用分支后:
你开发的IOS App已经测试完毕,提交到APPStore审核,根据你提交的版本号建立一个分支,在APPStore审核过程中你可能又开发了些功能但还没通过测试,这时APPStore把你的应用退回了,可能是你的Welcome图片不合格需要换一下,到这里你完全可以轻松应对,只需要把之前建立的那个分支签出到本地,修改后提交。
使用分支后整个过程So easy~
分支里保存的实际上是你建立分支时代码的快照,在分支上进行的修改还可以合并到主干中。
什么是标签?
标签和分支的本质是一样的,可以看到TortoiseSVN中,标签和分支实际上在一个菜单:
分支与标签的使用也是约定俗称的,混用分支与标签SVN也不会禁止。
标签用来记录项目中的事件或里程碑,可以让你给项目中的事件起一个名字,比如发布2.0.0版本,以后你可以使用这个名字来签出它。
标签与分支对比
还是继续上面的例子:
APPStore审核通过,这时你应该为分支建立一个标签,然后将分支的修改合并到主干,然后删除分支。
更直白的说,你可以在分支上进行并行开发,而不应该修改标签里的内容,标签仅应当作为一份代码的快照。
本篇先将理论,下篇讲解使用TortoiseSVN进行分支和标签的实际操作,网上查了下,发现使用TortoiseSVN的分支合并操作居然全是错的,所以感觉到非常有必要写出来,明天更新~
记录,为更好的自己!转载请注明出处~
阅读(...) 评论()

参考资料

 

随机推荐