java面试要点005---git和svn的区别
最近开始学Git,跟以前常用的SVN来做个对比,以便对双方的优缺点了解更多些。
其实Git和SVN还是挺像的,都有提交,合并等操作,看来这是源码管理工具的基本操作。
1. Git是分布式的,SVN是集中式的,好处是跟其他同事不会有太多的冲突,自己写的代码放在自己电脑上,一段时间后再提交、合并,也可以不用联网在本地提交;
2. Git下载下来后,在本地不必联网就可以看到所有的log,很方便学习,SVN却需要联网;
3. Git鼓励分Branch,而SVN,说实话,我用Branch的次数还挺少的,SVN自带的Branch merge我还真没用过,有merge时用的是Beyond Compare工具合并后再Commit的;
4. Tortoise也有出Git版本,真是好东西;
5. SVN在Commit前,我们都建议是先Update一下,跟本地的代码编译没问题,并确保开发的功能正常后再提交,这样其实挺麻烦的,有好几次同事没有先Updata,就
Commit了,发生了一些错误,耽误了大家时间,Git可能这种情况会少些。
大家也可以搜一搜Git和SVN命令的比对。
下面有一篇文章这样讨论,楼主认为SVN没什么用,我比较认同Ghoststears的观点。
有了GIT,SVN纯粹一垃圾
Ghoststears:
任何事情,归根结底都是人的问题,工具只是工具。
集中式管理的工作流程如下图:
下图是经典的git开发过程。
SVN属于集中化的版本控制系统
这种做法带来了许多好处,特别是相较于老式的本地VCS来说。现在,每个人都可以一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限。
事分两面,有好有坏。这么做最显而易见的缺点是中央服务器的单点故障。若是宕机一小时,那么在这一小时内,谁都无法提交更新、还原、对比等,也就无法协同工作。如果中央服务器的磁盘发生故障,并且没做过备份或者备份得不够及时的话,还会有丢失数据的风险。最坏的情况是彻底丢失整个项目的所有历史更改记录,被客户端提取出来的某些快照数据除外,但这样的话依然是个问题,你不能保证所有的数据都已经有人提取出来。
Subversion原理上只关心文件内容的具体差异。每次记录有哪些文件作了更新,以及都更新了哪些行的什么内容。
Subversion的特点概括起来主要由以下几条:
1.每个版本库有唯一的URL(官方地址),每个用户都从这个地址获取代码和数据;
2.获取代码的更新,也只能连接到这个唯一的版本库,同步以取得最新数据;
3.提交必须有网络连接(非本地版本库);
4.提交需要授权,如果没有写权限,提交会失败;
5.提交并非每次都能够成功。如果有其他人先于你提交,会提示“改动基于过时的版本,先更新再提交”… 诸如此类;
6冲突解决是一个提交速度的竞赛:手快者,先提交,平安无事;手慢者,后提交,可能遇到麻烦的冲突解决。
Git属于分布式的版本控制系统
自2005年诞生于以来,Git日臻成熟完善,在高度易用的同时,仍然保留着初期设定的目标。它的速度飞快,极其适合管理大项目,它还有着令人难以置信的非线性分支管理系统,可以应付各种复杂的项目开发需求。
与SVN不同,Git记录版本历史只关心文件数据的整体是否发生变化。Git并不保存文件内容前后变化的差异数据。实际上,Git更像是把变化的文件作快照后,记录在一个微型的文件系统中。每次提交更新时,它会纵览一遍所有文件的指纹信息并对文件作一快照,然后保存一个指向这次快照的索引。为提高性能,若文件没有变化,Git不会再次保存,而只对上次保存的快照作一连接。
简略的说,Git具有以下特点:
1.Git中每个克隆(clone)的版本库都是平等的。你可以从任何一个版本库的克隆来创建属于你自己的版本库,同时你的版本库也可以作为源提供给他人,只要你愿意。
2.Git的每一次提取操作,实际上都是一次对代码仓库的完整备份。提交完全在本地完成,无须别人给你授权,你的版本库你作主,并且提交总是会成功。
3.甚至基于旧版本的改动也可以成功提交,提交会基于旧的版本创建一个新的分支。
4.Git的提交不会被打断,直到你的工作完全满意了,PUSH给他人或者他人PULL你的版本库,合并会发生在PULL和PUSH过程中,不能自动解决的冲突会提示您手工完成。
5.冲突解决不再像是SVN一样的提交竞赛,而是在需要的时候才进行合并和冲突解决。
若是开源项目,则git更加适合,每个人都可以维护自己专属的版本,同时有github开源社区支持。
java面试要点005---git和svn的区别相关推荐
- java面试要点---ArrayList list = new ArrayList(); 在这个泛型为Integer的ArrayList中存放一个String类型的对象。
java面试要点---ArrayList list = new ArrayList(); 在这个泛型为Integer的ArrayList中存放一个String类型的对象. ArrayList list ...
- git与svn的区别面试
Git是分布式版本控制系统,它没有中央服务器,每个人的电脑就是一个完整的版本库,这样工作的时候就不需要联网了,因为版本都是在自己的电脑上.既然每个人的电脑都有一个完整的版本库,那多个人如何协作呢?比如 ...
- git与svn的区别 ?Git 与 SVN那个更好?
git与svn的区别 : http://www.360doc.com/content/12/1228/20/11220452_256857021.shtml 在版本控制系统的选型上,是选择Git还是S ...
- git与svn的区别及优缺点
git与svn的区别及优缺点 svn: 只有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连接到这台服务器,去除最新的文件或者提交更新. 集中式版本控制系统: 版本库 ...
- GIT 和 SVN的区别
Git了解 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目 Git 不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等. 如果你是一个具有使用 SVN ...
- Git和SVN的区别,Git的使用方法大全
什么是Git: Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控 ...
- 版本控制系统GIT和SVN的区别
两个都使用过,但是就保存代码来说,我偏向于SVN,而且用的比较熟练.但是GIT也有它的优势所在. 1)Git是分布式的,SVN不是: 这 是git和其它非分布式的版本控制系统,例如SVN,CVS等,最 ...
- 解读Git与SVN的区别(集中式VS分布式)
Git是目前世界上最先进的分布式版本控制系统,其实 Git 跟 SVN一样有自己的集中式版本库或服务器,但是Git 更倾向于被使用于分布式模式,也就是每个开发人员从中心版本库/服务器上chect ou ...
- Git和SVN的区别与联系
1.什么是Git[多] GIT,全称是分布式版本控制系统,git通常在编程中会用到,并且git支持分布式部署,可以有效.高速的处理从很小到非常大的项目版本管理.分布式相比于集中式的最大区别在于开发者可 ...
最新文章
- Android SQLite开发调试工具 Android Debug Database
- Hadoop自学笔记(三)MapReduce简单介绍
- C++设计模式-使用Qt框架采用简单工厂模式实现商城打折满减案例
- vue+django前后端项目部署
- html标签--!DOCTYPE (怪异模式和DTD)
- swift项目调用OC库 和OC项目 在swift文件里面全局调用OC库
- 扬州大学c语言上机作业答案,扬州大学C语言上机作业1-9整理
- 将纯真ip数据库导入MySql
- CUDA error: invalid device ordinal
- 国美易卡有序实现索引,国美易卡B+树方便区间查找
- 陀螺仪工作原理及创新应用
- hulu dpp_什么是直播电视的Hulu,它可以代替您的有线电视订阅吗?
- 沐风:可怕的想什么就来什么
- 3星|《一万年的爆发:文明如何加速人类进化》:那些拒绝承认欧洲征服和定居美洲过程中生物学差异的人,事实上也是在否认达尔文进化论...
- html弹性盒子垂直排列,css3弹性盒子布局
- 对话汇医慧影联合创始人郭娜:人工智能是分级诊疗的必然抓手
- 墨客FileStorm生态与四块科技生态联合发布会
- 序列密码知识整理(一 简介)
- php curl couldnt connect to host,linux curl命令:curl: (7) couldn't connect to host ?
- python bind_Python tkinter之Bind(绑定事件)的使用示例