SVN和GIT的比较(一)

来源:互联网 发布:matlab 稀疏矩阵求逆 编辑:程序博客网 时间:2024/04/20 06:59

1. GIT是分布式的

          每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库;设想突然遇到没有网络的环境时,你仍然能够提交文件,查看历史版本记录,创建项目分支;等网络再次连接上Push到Server端。

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

       资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里,git目录是处于你的机器上的一个克隆版的版本库,它拥有中心版本库上所有的东西,例如标签,分支,版本记录等。所以git的目录和.SVN的体积大小区别。

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

       分支在SVN中是版本库中的另外的一个目录。如果你想知道是否合并了一个分支,你需要手工运行像这样的命令svn propget svn:mergeinfo,来确认代码是否被合并。

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

 1-3文章转自:http://blog.jobbole.com/31444/


4. 分支(Branch)

       Git,每个工作成员可以任意在自己的本地版本库开啟无限个分支。举例:当我想尝试破坏自己的程序(安检测试),并且想保留这些被修改的文件供日后使用, 我可以开一个分支,做我喜欢的事。完全不需担心妨碍其他工作成员。只要我不合并及提交到主要版本库,没有一个工作成员会被影响。等到我不需要这个分支时, 我只要把它从我的本地版本库删除即可。

5. 版本库(repository)

      SVN只能有一个指定中央版本库。当这个中央版本库有问题时,所有工作成员都一起瘫痪直到版本库维修完毕或者新的版本库设立完成。

      Git可以有无限个版本库。或者,更正确的说法,每一个Git都是一个版本库,区别是它们是否拥有活跃目录(Git Working Tree)。如果主要版本库(例如:置於GitHub的版本库)发生了什麼事,工作成员仍然可以在自己的本地版本库(local repository)提交,等待主要版本库恢复即可。

4-5目录文章来源如下

文/白袍君(简书作者)
原文链接:http://www.jianshu.com/p/bfec042349ca
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

文/白袍君(简书作者)
原文链接:http://www.jianshu.com/p/bfec042349ca
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。


0 0