Git和SVN区别

听说要用Git了,先了解下。

听说习惯用SVN的,需要好好转换下,才能理解Git。

听说Git不仅仅是版本控制系统,它还内容管理、工作管理啥的。

 

这篇文章先了解下。。 

 

1.GIT是分布式的,SVN、CVS啥的不是~

1)GIT也有集中式版本库,但是更倾向于分布式。 即开发者从中心版本库check out下代码后,会在本地自己机器上克隆一个自己的版本库。

这样,你就可以在一个没有网络的环境里,提交代码,创建分支等。非常便利。

2)对于开源项目,而只需创建一个分支,向项目团队发送推请求。

这样,可保持你的代码是最新,而且不会在传输中把代码丢失。

最重要的是,不用再找开源管理的童鞋做一系列的操作~非常便利。


2. GIT是按元数据存储,而SVN是按文件。

所有的资源控制系统都是把文件的元信息隐藏在一个类似的.svn,.cvs这样的文件夹中。

.git目录是在你机器上的一个克隆版的版本库,拥有中心版本库上所有的东西,如标签、分支、版本记录等。

 

3. GIT分支和SVN分支不同

在使用SVN时,建立分支和合并分支有时候比较痛苦,特别是合并主干,如果新建立的项目还好,但是如果在一个老的项目上开发新东西,合并就很头疼。。

总之,用分支用的就比较少,特别是后来做的项目都很单一,或者锁版本这种,这个几乎也很少用了。

如果是否合并了一个分支,命令行:svn propget svn:mergeinfo,来确认代码是否被合并。

 

GIT分支很简单。 可以从同一个工作目录下快速的在几个分支间切换。

也很容易发现未被合并的分支,简单快捷的合并这些文件。 


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

SVN的版本号实际上是任何一个相应时间的源代码快照。

GIT可以用SHA-1来唯一标识一个代码快照。但不方便吧?

 

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

GIT的内容存储使用的SHA-1算法。能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

 

我觉得下边的内容更有意思~


6. 速度:

克隆一份全新目录,比如说五个分支的。SVN需要同时复制5个版本的文件。很慢,深有体会。

GIT只获取文件的每个版本的元素,然后载入主要的分支(master)。

所以GIT的速度远远快于SVN。 


7. 版本库(repository):

SVN只能有一个指定的中央版本库。一旦中央版本库有问题,所有人都会瘫痪,并只能等待版本库修复ok。

GIT有无限个版本库。每一个GIT都是一个版本库,区别在于他们是否有活跃目录(Git Working Tree)。 如果主要版本库有问题,其他人还可以在自己的本地版本库提交,等待主版本库修复。也可以提交到其他的版本库。

 

8. 分支(Branch):

 

9.提交(Commit)

SVN中提交,直接影响中央版本库。

GIT的提交,属于本地版本库的活动。 只需要“推”git push 到主要版本库即可。GIT的推,其实是执行同步。


10.重新设立起点(Rebase):

GIT中,git rebase branch_name,即可把别人最新提交的代码设立为现在分支的起点。

merge会依据修改的时间视为最新,而rebase要求解决双方都有修改过的地方的矛盾。

 

11. 系统档案:

SVN的每个目录下都有.svn。移除也很麻烦。

GIT会在目录起点有一个.git目录,以及.gitignore。 


搞完这些,突然觉得可以用下新东西了,虽然也不新了。。。 

 

posted on 2015-06-26 10:19  hanyuxinting  阅读(226)  评论(0编辑  收藏  举报

导航