git和svn 的区别

一:svn :

集中式的数据管理,存在一个中央版本库。所有开发人员本地开发所以用的代码均来自这个版本库,提交代码也必须提交到这个中央版本库中。

svn的版本控制流程如下:

1:在中央库中常见或从主干复制一个分支;

2:从中央库checkout下这个分支的代码;

3:增加自己的代码文件,修改现存的代码或删除代码文件;

4:commit代码,如果有人在刚刚的分支上提交了代码,你的commit 会提示代码过期,需要你现up你的代码在提交,如果出现冲突,解决完冲突在提交代码。

使用缺点:

1:需要局域网配合,若断网,则无法提交和更新代码;

2:代码集中管理,需要对中央版本库进行备份,以防版本出现混乱失控的情况。备份是要备份所有的代码数据以及所以更改的版本记录;

3:容错性差。

二:git 

git :分布式的版本控制,由Linux 开发,每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库,创建自己的分支,并进行开发操作,减少冲突,即使是无网络的环境,也能提交代码,查看版本,查看提交记录等。

三:svn 和git 的区别

gitsvn
分布式集中式
内容按照元数据方式存储,按照文件存储
同一目录下可以有多个分支,代码合并分支简单分支不能放在同一个目录下,需要另外目录管理,需要手工合并分支
git 没有全局版本号存在全局版本号
存储内容使用sha-1哈希算法,代码内容较为完整svn是按项目集中进行管理,按目录进行分类管理(需求分析,设计、美工、测试、代码等等),适合于项目管理
git 下载,不联网也可以看logsvn 需要联网
直接合并,解决冲突简单commit 代码前,需要钱update一下,直接合并可能会覆盖其他人的代码

 

GitSVN是两种常用的版本控制系统,它们有一些重要的区别。 1. 分布式 vs 集中式:Git是一种分布式版本控制系统,每个开发者都拥有完整的代码仓库副本,可以在本地进行提交、分支合并等操作,不需要依赖服务器。而SVN是一种集中式版本控制系统,开发者需要从中央服务器获取代码并提交更改。 2. 速度:Git通常比SVN更快。因为Git在本地存储了完整的代码仓库,不需要频繁地与服务器通信。而SVN需要与中央服务器进行交互,因此速度相对较慢。 3. 分支合并:Git具有强大的分支合并功能,允许开发者轻松创建、切换合并分支,这使得并行开发团队协作更加灵活。SVN的分支合并相对较为复杂,需要手动创建分支,并在合并时可能会出现冲突。 4. 历史记录:Git存储了每次提交的完整快照,可以轻松地查看历史记录,并回滚到任意版本。SVN只存储了每个文件的差异,查看历史记录相对不方便。 5. 分布式开发:由于Git是分布式的,开发者可以在没有网络连接的情况下进行提交、分支合并等操作。SVN需要与中央服务器通信,因此需要网络连接才能进行开发。 总的来说,Git适用于分布式开发、并行开发大规模项目,具有更快的速度强大的分支合并功能。SVN适用于小型项目集中式开发,对于不熟悉分布式版本控制的团队来说更容易上手。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值