GIT 和 SVN 之间的五个基本区别

本文探讨了GIT与SVN两种版本控制系统之间的五个根本区别,包括分布式特性、内容存储方式、分支管理、版本编号机制及内容完整性保障,旨在帮助开发者更好地理解这两种工具的特点。

Git LogoSVN Logo

如果你在读这篇文章,说明你跟大多数开发者一样对GIT感兴趣,如果你还没有机会来试一试GIT,我想现在你就要了解它了。

GIT不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等。如果你是一个具有使用SVN背景的人,你需要做一定的思想转换, 来适应GIT提供的一些概念和特征。所以,这篇文章的主要目的就是通过介绍GIT能做什么、它和SVN在深层次上究竟有什么不同来帮助你认识它。

那好,这就开始吧…

  1. GIT是分布式的,SVN不是:

    这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。如果你能理解这个概念,那么你就已经上手一半了。需要做一点声 明,GIT并不是目前第一个或唯一的分布式版本控制系统。还有一些系统,例如Bitkeeper, Mercurial等,也是运行在分布式模式上的。但GIT在这方面做的更好,而且有更多强大的功能特征。

    GIT跟SVN一样有自己的集中式版本库或服务器。但,GIT更倾向于被使用于分布式模式,也就是每个开发人员从中心版本库/服务器上 chect out代码后会在自己的机器上克隆一个自己的版本库。可以这样说,如果你被困在一个不能连接网络的地方时,就像在飞机上,地下室,电梯里等,你仍然能够提 交文件,查看历史版本记录,创建项目分支,等。对一些人来说,这好像没多大用处,但当你突然遇到没有网络的环境时,这个将解决你的大麻烦。

    同样,这种分布式的操作模式对于开源软件社区的开发来说也是个巨大的恩赐,你不必再像以前那样做出补丁包,通过email方式发送出去,你只需要创建一个分支,向项目团队发送一个推请求。这能让你的代码保持最新,而且不会在传输过程中丢失。GitHub.com就是一个这样的优秀案例。

    有些谣言传出来说subversion将来的版本也会基于分布式模式。但至少目前还看不出来。

  2. GIT把内容按元数据方式存储,而SVN是按文件:

    所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。如果你把.git目录的体积大小跟.svn比较,你会发 现它 们差距很大。因为,.git目录是处于你的机器上的一个克隆版的版本库,它拥有中心版本库上所有的东西,例如标签,分支,版本记录等。

  3. GIT分支和SVN的分支不同:

    分支在SVN中一点不特别,就是版本库中的另外的一个目录。如果你想知道是否合并了一个分支,你需要手工运行像这样的命令svn propget svn:mergeinfo,来确认代码是否被合并。感谢Ben同学指出这个特征。所以,经常会发生有些分支被遗漏的情况。

    然而,处理GIT的分支却是相当的简单和有趣。你可以从同一个工作目录下快速的在几个分支间切换。你很容易发现未被合并的分支,你能简单而快捷的合并这些文件。

  4. GIT没有一个全局的版本号,而SVN有:

    目前为止这是跟SVN相比GIT缺少的最大的一个特征。你也知道,SVN的版本号实际是任何一个相应时间的源代码快照。我认为它是从CVS进化 到 SVN的最大的一个突破。因为GIT和SVN从概念上就不同,我不知道GIT里是什么特征与之对应。如果你有任何的线索,请在评论里奉献出来与大家共享。

    更新:有些读者指出,我们可以使用GIT的SHA-1来唯一的标识一个代码快照。这个并不能完全的代替SVN里容易阅读的数字版本号。但,用途应该是相同的。

  5. GIT的内容完整性要优于SVN:

    GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。这里有一个很好的关于GIT内容完整性的讨论 – http://stackoverflow.com/questions/964331/git-file-integrity

GIT和SVN之间只有这五处不同吗?当然不是。我想这5个只是“最基本的”“最吸引人”的,我只想到这5点。如果你发现有比这5点更有趣的,请共享出来,欢迎。

[英文出处]:5 Fundamental differences between GIT & SVN

转自:http://www.oschina.net/news/12542/git-and-svn


本文是使用 B3log Solo简约设计の艺术 进行同步发布的
原文地址:http://b3log-88250.appspot.com/articles/2010/10/20/1287536756432.html

Git SVN 是两种常见的版本控制系统,它们在设计理念、功能特性适用场景上有显著的区别。以下是对 Git SVN区别对比: ### 1. 分布式 vs 集中式 Git 是一个分布式版本控制系统,这意味着每个开发者都可以拥有完整的代码仓库,包括完整的历史记录版本信息。这种设计使得 Git 更适合于分布式团队协作,支持离线工作,并且提高了系统的可靠性灵活性[^1]。相比之下,SVN 是一个集中式版本控制系统,所有的版本数据都存储在一个中央服务器上,开发者需要连接到这个服务器来获取或提交代码[^1]。 ### 2. 分支与合并 Git 提供了强大的分支管理合并功能。创建分支合并分支的操作非常快速高效,这使得 Git 成为了需要频繁进行分支合并操作项目的理想选择[^1]。而 SVN 虽然也支持分支标签,但这些操作相对较为笨重,尤其是在处理大量分支时,可能会遇到性能问题。 ### 3. 性能 由于 Git 是分布式的,大部分操作都可以在本地完成,因此通常比 SVN 更快。例如,提交更改、查看历史记录切换分支等操作在 Git 中都非常迅速。SVN 的性能则受限于网络连接的速度,特别是在执行需要访问远程仓库的操作时[^1]。 ### 4. 学习曲线 Git 的命令行工具功能强大,但同时也更加复杂。它提供了丰富的命令选项,如 `fetch`、`merge` `rebase` 等,这要求开发者投入更多的时间精力去学习理解 Git 的工作流程[^2]。SVN 的操作相对简单,对于新手来说更容易上手,但它在代码变更控制方面的功能不如 Git 强大[^2]。 ### 5. 二进制文件处理 对于包含大量不可合并的二进制文件的企业项目,SVN 可能是一个更好的选择。Git 在处理二进制文件时效率较低,因为每次提交都会生成一个新的快照,这可能导致仓库体积迅速膨胀[^3]。 ### 6. 社区支持 Git 拥有一个庞大且活跃的社区,提供了大量的文档、教程第三方工具支持。这使得 Git 用户能够轻松找到解决问题的方法支持资源。SVN 同样有不错的社区支持,但随着 Git 的普及,SVN 的社区活跃度有所下降。 ### 7. 安全性 Git 通过 SHA-1 哈希算法确保数据的完整性安全性。每个提交都有一个唯一的哈希值,任何对提交内容的修改都会改变哈希值,从而被检测到。SVN 也提供了安全机制,但在数据完整性防篡改方面不如 Git 强大。 ### 示例代码 以下是一个简单的 Git 操作示例,展示了如何初始化一个新的仓库、添加文件并提交更改: ```bash # 初始化新仓库 git init # 添加文件到仓库 git add README.md # 提交更改 git commit -m "Initial commit" ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值