如果你在读这篇文章,说明你跟大多数开发者一样对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点更有趣的,请共享出来,欢迎。
相关推荐
多项目管理方面,Git需要为每个项目和每个组件建立单独的仓库,而SVN则可以将多个项目或组件集中存储在同一个仓库内,大大减少了需要管理的仓库数量。 版本号的表示方式也不同,Git使用128位的ID作为版本号,而SVN...
与传统集中式工作模式的异同 4.2.3. 合并后推送 4.2.4. 合并还是变基 4.1.1. 版本库派生 4.1.2. Pull Request 4.1.3. 手工合并 4.1.4. 在线编辑 4.1.5. 简化的 Fork Pull Request 4.1. Fork Pull模式 4.2....
《svnbook》可能会提及SVN与Git的异同,帮助你理解在何种情况下选择哪种工具更为合适。 9. **高级特性**:除了基础操作,书中还涵盖了如锁定、忽略文件、日志查看、导出、导入选项等高级功能,帮助你充分利用SVN的...
而“git 分布式 mercurial”的标签,则将Mercurial与另一种著名的DVCS——Git进行了关联,暗示我们将对比两者之间的异同。 Mercurial的核心概念在于其分布式特性。与集中式的版本控制系统(如CVS或SVN)不同,每个...
6. **版本控制集成**:BCompare可与Git、SVN等版本控制系统集成,直接在比对界面查看版本间的差异,提高工作效率。 7. **文件夹比对**:除了单个文件,BCompare还可以对比整个目录结构,用于项目迁移、备份验证或者...
3. **版本控制集成**:对于使用版本控制系统(如Git、SVN)的团队,SQL.Delta可以与之无缝集成,方便地管理数据库变更历史。 4. **报表生成**:它可以生成详细的比较报告,有助于团队成员理解和审查更改。 5. **...
它的界面简洁明了,通过鲜明的颜色区分不同之处,使用户一眼就能识别出两个文件或代码之间的异同。Kaleidoscope支持多种文件格式,包括文本文件、图片、JSON、XML等,这使得它在日常开发工作中极具实用性。此外,...
BeyondCompare可以与多种版本控制系统(如Git、SVN等)集成,直接在工具内部进行版本比较和冲突解决,提升了开发效率。 四、自定义规则 为了满足不同场景的需求,BeyondCompare允许用户自定义比较规则,例如设置...
4. 配合版本控制系统:与Git、SVN等版本控制系统无缝集成,使得在提交或拉取代码时能轻松对比差异。 二、常用源码对比工具 1. Beyond Compare:这是一款广受欢迎的跨平台比较工具,提供了强大的文本、文件夹、...
文件比较工具是IT行业中不可或缺的一种实用软件,它主要用于检测两个或多个文件之间的差异,或者比较文件夹、文本、图片、16进制数据等不同类型的文件。这些工具在软件开发、文档管理、版本控制以及日常的数据比对...
5. **SQL Source Control**:整合了版本控制系统(如Git、SVN等)与SQL Server Management Studio,使得数据库对象也能像代码一样进行版本控制。 6. **.NET Memory Profiler**:用于检测.NET应用程序的内存使用情况...
6. **版本控制集成**:高级的SQL脚本对比工具可能支持与Git、SVN等版本控制系统集成,便于版本管理和历史追踪。 在提供的"Beyond Compare"这个工具中,用户可以利用其强大的文本比较功能来处理SQL脚本。它不仅可以...
3. 集成版本控制系统:它无缝集成了Git、SVN、Perforce等主流版本控制系统,使得在版本历史中查找和解决冲突变得更加简单。 4. 合并冲突:当多个开发者同时修改同一份文件时,可能会产生冲突。Araxis Merge提供了...
文件目录对比工具是一种高效实用的软件,用于比较和同步两个或多个文件夹或者文件之间的差异。在日常工作中,我们可能需要检查更新、合并代码、管理版本或者查找误删的文件,这时文件对比工具就能派上大用场。本文将...
在这个场景下,"文件对比界面代码"指的是实现这个功能的编程代码,可能是用某种编程语言如Java、Python或C#编写,用于创建一个用户界面,展示并分析两个文件的异同。 文件对比的基本原理通常是通过算法比较文件的每...
5. **版本控制集成**:与Git、SVN等版本控制系统无缝集成,方便代码审查和版本回溯。 6. **目录比较**:不仅仅比较单个文件,还可以比较整个目录结构,包括子目录内的所有文件。 7. **自定义设置**:允许用户根据...
- 与Git、SVN等版本控制系统的良好配合,可以快速查看文件的版本历史和差异。 7. **自动化比对**: - 可以通过命令行接口(CLI)进行自动化脚本编写,批量处理比对任务。 8. **跨平台性**: - 许多比对工具支持...
4. **版本控制**:与版本控制系统(如Git、SVN)集成,便于查看每次提交的变化。 了解并熟练掌握一款或几款代码对比工具是每个程序员的必备技能之一。不论是修复bug、跟踪代码变更还是协同开发,这些工具都能显著...
5. **版本控制集成**:与Git、SVN等版本控制系统结合,方便查看和解决代码冲突。 6. **自定义规则**:用户可以设置比较规则,如忽略空格、大小写敏感性等,以适应不同场景。 7. **报告生成**:生成比较报告,便于...
5. **版本控制集成**:WinMerge可以与常见的版本控制系统如Git、SVN等无缝集成,直接在提交前进行文件的比较和合并。 ### 二、使用场景 1. **代码开发**:开发者在进行代码编写时,经常需要对比不同版本的源代码,...