一张图搞定源代码管理之SVN

开发过程中离不开源代码的管理,下面让我们先了解一下关于源代码管理的知识.

为什么会出现源代码管理工具?

  • 为了解决在软件开发过程中,由源代码引发的各种蛋疼、繁琐的问题

源代码会引发哪些问题?

  • 无法后悔:做错了一个操作后,没有后悔药可以吃

  • 版本备份:费空间、费时间

  • 版本混乱:因版本备份过多造成混乱,难于找回正确的想要的版本

  • 代码冲突:多人操作同一个文件(团队开发中的常见问题)

  • 权限控制:无法对源代码进行精确的权限控制

  • 追究责任:出现了严重的BUG,无法得知是谁干的,容易耍赖
    … …

  • 源代码管理工具就是为了解决上述问题而生的!此乃软件开发的一大福音!

概括一下,源代码管理工具的作用是

  • 能追踪一个项目从诞生一直到定案的过程
  • 记录一个项目的所有内容变化
  • 方便地查阅特定版本的修订情况

使用源代码管理工具好处

  • 由于使用简单,不会增加工作量

  • 不会对现有工作造成任何损害(坏的影响)

  • 是一位合格的软件开发人员必须掌握的技术

  • 注意:

    • 如果是团队开发,使用源代码管理工具是强制性的!
    • 如果是单人开发,也强烈建议现在就开始使用源代码管理工具

那么下面列举一下常见的源代码管理工具

CVS

  • 开启版本控制之门
  • 1990年诞生,“远古时代”的主流源代码管理工具

SVN

  • 全称是Subversion,集中式版本控制之王者
  • 是CVS的接班人,速度比CVS快,功能比CVS多且强大
  • 在国内软件企业中使用最为普遍(70%~90%)

GIT

  • 一款伟大的分布式源代码管理工具
  • 目前被越来越多的开源项目使用
  • 不过在国内企业尚未大范围普及

接下来我们介绍这篇文章的重点SVN(说明:一般程序员是没有机会安装SVN服务器的,都是由项目经理或者技术总监安装,所以就不给大家详细写下安装的过程了)

  • 同样给大家介绍一些基础知识

概念:

  • Repository 代码仓库,保存代码的仓库
  • Server 服务器,保存所有版本的代码仓库
  • Client 客户端,只保存当前用户的代码仓库
  • 用户名&密码 访问代码仓库需要使用自己的"用户名和密码",从而可以区分出不同的人对代码做的修改

最常使用的3个操作:

  • checkout 将服务器上最新的代码仓库下载到本地,只需要做一次
  • update 从服务器上将其他人所做的修改下载到本地,每天上班必须要做的事情
  • commit 将工作提交到服务器,每天下班之前至少做一次

UNIX常用命令(不使用图像化界面时候使用)

  • cd 改变工作目录

  • pwd 输出当前工作目录的绝对路径

  • 在UNIX中要执行什么命令,一定要知道自己当前所在的工作目录

  • ls 查看文件

  • ls 显示文件

  • ls -a 显示所有文件

  • ls -l 列表显示文件

  • ls -la 列表显示所有文件

  • touch 用于更改文件访问和修改时间的标准UNIX程序,也被用于创建新文件touch test.txt

  • 注意:touch不修改test.txt内容,只更改它的访问、修改时间,如果test.txt不存在,它会被创建

  • cat 连续查看文件内容

  • more 分页查看文件内容

提示:

  • 命令和参数之间需要添加空格
  • 如果要使用当前目录中的文件名,输入到一半时,按TAB键能够补全

图形界面工具

  • 在Mac上,也可以利用SVN图形界面工具来管理源代码,可以大大减小使用命令行的痛苦(有些操作使用命令行会比较繁琐,比如解决冲突)

  • 工具: Cornerstone / Versions / Xcode

  • 大部分工作在Xcode中都可以完成

  • Xcode对SVN的支持并不是非常友好,尤其新建文件夹时,在Xcode中非常容易出问题

注意

  • Xcode中,最好不要多人同时修改一个Storyboard!

ok下面让我们一张图搞定SVN

SVN.png

注释:上图中使用了一些缩写如下:

  • svn checkout :下载服务器的代码到本地 (简写svn co
  • svn commit :将改动的文件提交到服务器(简写svn ci
  • svn update :更新服务器的代码到本地 (简写svn up
  • svn delete、svn remove :从本地的版本控制库中删除文件(简写svn delsvn rm

看了上图是不是感觉源代码管理的流程已经很清除了呢,在使用过程中可能会遇到一些问题,下面给大家总结一下常见问题

  • 去到公司的第一天,下载公司的代码到电脑上
    svn checkout
  • 修改了某个早已存在的旧文件,然后提交到服务器
    svn commit
  • 提交一个自己新建的文件到服务器
    svn add -> svn commit
  • 删除一个早已存在的旧文件,然后同步到服务器上
    svn delete -> svn commit
  • 将其他同事提交的新代码更新到自己电脑上
    svn update
  • 不小心写错了很多东西,想撤销所写的东西(还未把修改提交到服务器)
    svn revert
  • 不小心删错了文件,想把文件恢复回来(还未把删除提交到服务器)
    svn revert
  • 不小心写错了很多东西,想撤销所写的东西(已经把修改提交到服务器)
    svn update -r 版本号
  • 不小心删错了文件,想把文件恢复回来(已经把删除提交到服务器)
    svn update -r 版本号

注:文件状态

svn st 显示的文件状态
  • ' ' 没有修改
  • A 被添加到本地代码仓库
  • C 冲突
  • D 被删除
  • I 被忽略
  • M 被修改
  • R 被替换
  • X 外部定义创建的版本目录
  • ? 文件没有被添加到本地版本库内
  • !文件丢失或者不完整(不是通过svn命令删除的文件)
  • ~ 受控文件被其他文件阻隔
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,529评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,015评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,409评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,385评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,387评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,466评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,880评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,528评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,727评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,528评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,602评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,302评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,873评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,890评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,132评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,777评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,310评论 2 342

推荐阅读更多精彩内容