一、为什么会出现源代码管理工具
为了解决在软件开发过程中,由源代码引发的各种不爽、繁琐的问题,
二、不采用源代码管理工具会出现什么问题
1、无法后悔:做错了一个操作后,没有后悔药可以吃
2、版本备份:费空间、费时间
3、版本混乱:因版本备份过多造成混乱,难以找回正确的想要的版本
4、代码冲突:多人操作同一个文件,团队开发中的常见问题
5、权限控制:无法对源代码进行精确的权限控制
6、追究责任:出现严重的bug,无法得知是谁干的,容易耍赖
三、源代码管理的作用
1、能追踪一个项目从诞生一直到定案的过程
2、记录一个项目的所有内容变化
3、方便查阅特定版本的修订情况
四、什么时候使用源代码管理工具
1、如果是团队开发,使用源代码管理工具是强制性的
2、如果是单人开发,也强烈建议开始使用源代码管理工具
3、使用简单,不会增加工作量
4、不会对现有工作造成任何损害
5、一名合格的开发人员必须掌握的技术
五、常见的源代码管理工具
1、CVS
1)开启版本控制之门
2)1990年诞生,远古时代的主流源代码管理工具
2、SVN
1)全称是Subversion,集中式版本控制王者
2)是CVS的接班人,速度比CVS快,功能比CVS多且强大
3)在国内软件企业中使用最为普遍(70%/80%)
3、GIT
1)一款伟大的分布式源代码管理工具
2)目前被原来越多的开源项目使用
3)不过在国内企业尚未大范围普及
SVN(集中式版本控制系统)
1、概念
版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。SVN在没有网络情况下是无法查看提交日志和文件对比的
2、使用步骤
1、刚接手这个项目,从中央服务器取得最新的项目
2、今天在项目里面加了一些功能,想要添加到中央服务器中
3、首先从中央服务器更新一下项目,确保没有错误
4、然后再将自己的工程给提交
PS:每次更新之前记得提交
三、Git(分布式版本控制系统)
1、概念
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。SVN在没有网络情况下是无法查看提交日志和文件对比的,Git没有影响