源代码管理SVN的使用
SVN
- 全称是Subversion,集中式版本控制之王者
- SVN 版本控制,需要自己搭建一个管理代码的服务器,提供开发人员,上传和下载
1.基本介绍

使用环境
要想利用SVN管理源代码,必须得有2套环境
服务器
- 用于存储客户端上传的源代码
- 可以在Windows上安装Visual SVN Server
- 大部分情况下,公司的开发人员不必亲自搭建SVN服务器
客户端
- 上传本地的源代码到服务器,或者更新服务器的代码到本地,保持同步
- 可以在Mac上使用命令行、Versions、Cornerstone、Xcode
- 开发人员就属于客户端这个角色
2.搭建服务器
服务器安装(windows安装)








服务器创建代码仓库








3.基本操作(命令行)
- 先进入创建的存放项目文件夹目录
项目经理初始化项目
①.将服务器所有的内容下载到本地
- svn checkout 服务器地址 —username=mgr —password=mgr
②.进⼊入到工作目录
- cd 工作目录
③.初始化项⺫
- touch main.m 添加文件和项目
④.将main.m加⼊入到本地代码管理中
- svn add main.m
⑤.将main.m提交到服务器
- svn commit -m “注释”
⑥.查看⽂文件的状态(svn status—>简写svn st)
- svn st 显示的文件状态
文件状态
- ' ' 没有修改
- 'A' 被添加到本地代码仓库
- 'C' 冲突
- 'D' 被删除
- 'I' 被忽略
- 'M' 被修改
- 'R' 被替换
- 'X' 外部定义创建的版本目录
- '?' 文件没有被添加到本地版本库内
- '!' 文件丢失或者不完整(不是通过svn命令删除的文件)
- '~' 受控文件被其他文件阻隔
⑦.删除
删除服务器上的某个文件,需要做2个步骤
- 将文件从本地的版本控制库中移除:svn delete 、svn remove
- 提交刚才的删除操作到服务器:svn commit
将文件从本地的版本控制库中移除
- svn delete 文件名
⑧.查看日志
查看日志,需要2个步骤
- 将服务器的最新代码更新到本地:svn update
- 查看日志:svn log
⑨.添加
提交一个新建的文件到服务器,需要2个步骤
- 添加新建的文件到本地的版本控制库中:svn add
- 提交刚才的添加操作到服务器:svn commit
如果直接提交一个没有添加到本地版本控制库中的文件,会报下面的错误
- is not a working copy
⑩.更新
将服务器的最新代码更新到本地
- svn update [PATH]
将文件恢复至某个版本
- svn update -r 版本号 [PATH]
⑪.代码冲突问题:
a.无法提交代码提示错误:out of date
- 过期—>如果本地的版本号⼩小于服务器的版本号是 不能提交
- 先更新一下,在查看冲突 conflict discovered
b.代码冲突的解决⽅方案:
- (p) postpone : 对⽐比所有的版本的代码,⼿手动解决冲突
- (mc) mine-conflict : 使⽤用我的代码覆盖服务器的代码
- (tc) theirs-conflict : 使⽤用服务器代码覆盖我的代码
- (df) diff-full : 展⽰示全部的不同.是在命令⾏行中展⽰示
- (e) edit : 直接编译⽂文件,但是也是在命令⾏行中编辑
- (s) show all options: 再次展⽰示所有的选项
c.选择postpone查看⽂文件中的代码
- 在冲突的文件中有冲突展示
<<<<<<< .mine
我的代码
=======
服务器的代码
>>>>>>> .r16
- 在代码中修改后保存文件
- 再删除多余的文件
d.解决冲突之后命名:svn resolved ⽂文件名
4.总结
去到公司的第一天,下载公司的代码到电脑上
- svn checkout
修改了某个早已存在的旧文件,然后提交到服务器
- svn commit
提交一个自己新建的文件到服务器
- svn add -> svn commit
删除一个早已存在的旧文件,然后同步到服务器上
- svn delete -> svn commit
将其他同事提交的新代码更新到自己电脑上
- svn update
不小心写错了很多东西,想撤销所写的东西(还未把修改提交到服务器)
- svn revert
不小心删错了文件,想把文件恢复回来(还未把删除提交到服务器)
- svn revert
不小心写错了很多东西,想撤销所写的东西(已经把修改提交到服务器)
- svn update -r 版本号
不小心删错了文件,想把文件恢复回来(已经把删除提交到服务器)
- svn update -r 版本号

5.图形化工具的使用(Xcode 和 Cornerstone/Versions)
一张图概括

Xcode工具不能忽略一些不需要的文件,可以使用命令行或者Cornerstone
注意a.用图形化工具导入静态库,必须用命令行 svn add 静态文件
b.为了避免冲突,尽量别和同事一起修改同一个文件
特别是storyboard或者xib文件c.经常commit 和 经常update
源代码管理SVN的使用的更多相关文章
- iOS开发——源代码管理——SVN
一.源代码管理(svn)简介 01. 源代码管理工具概述 ======================================================================= ...
- iOS源代码管理svn
01. SVN介绍 SVN 是集中式源代码管理工具 概念: 1> Repository 代码仓库,保存代码的仓库 2> Server 服务器,保存所有版本的代码仓库 3&g ...
- iOS开发——源代码管理——svn 命令行下常用的几个命令
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/pro/domai ...
- git与svn, tfs等源代码管理器的协同
简单地说,这三个都是业界知名的源代码管理器.他们是有区别的,根本的区别在于git是分布式源代码管理器(每个本地都有完整的代码,及历史),而svn和tfs是集中式源代码管理器(只有服务器才有完整的历史, ...
- 源代码管理工具之SVN
源代码管理工具SVN是一款非常强大的源代码管理工具,现在国内70%-90%的公司都在使用SVN来管理源代码,下面就让小编给大家着重介绍一下SVN的使用,SVN的使用主要分为下面几块. SVN的使用环境 ...
- iOS 源代码管理工具之SVN
源代码管理工具之SVN 源代码管理工具SVN是一款非常强大的源代码管理工具,现在国内70%-90%的公司都在使用SVN来管理源代码,下面就让小编给大家着重介绍一下SVN的使用,SVN的使用主要分为下面 ...
- 源代码管理工具(上)-SVN基本使用
------------------------------------------------------SVN简介和搭建 ------------------------------------- ...
- Linux企业级项目实践之网络爬虫(25)——管理源代码之SVN
软件项目开发中,一般会用到源代码管理工具SVN.版本控制是管理数据变更的一种技术.对于程序员来说,它已经成为不可或缺的工具,因为他们经常修改软件代码,产生部分的变更,然后第二天再取消所有的变更.想象有 ...
- iOS核心笔记—源代码管理工具-SVN
源代码管理工具-SVN 一. 源代码管理工具概述 1. 源代码管理工具的作用? > 能追踪一个项目从诞生一直到定案的过程 > 记录一个项目的所有内容变化,无限制返回 > 查看特定版本 ...
随机推荐
- Cocos2dx 小技巧(十三)聊聊坐标系
一好友考上了空姐.她说:以后基本上不会回来了.等下次见面时请叫我白富美!尽管有点羡慕.但我依然不甘示弱回复:下次见面时请叫我高富帅! 未来,谁说得准呢? ------------------有段时间没 ...
- 杭电 1150 moving tables
http://acm.hdu.edu.cn/showproblem.php? pid=1050 Moving Tables Time Limit: 2000/1000 MS (Java/Others) ...
- [NOIP2012] day2 T3疫情控制
题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都,也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散到 ...
- HDU1754 —— I Hate It 线段树 单点修改及区间最大值
题目链接:https://vjudge.net/problem/HDU-1754 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜 ...
- frameset 框架整体退出登录的问题
1 设置其他的页面都验证session,如果session不存在就跳转到 Login 页: 2 Login中添加下面的js代码: <script language="JavaScrip ...
- BZOJ4561:圆的异或并(扫描线+set||splay||线段树)
在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个圆内则不考虑. I ...
- facebook chat api 使用
官方API文档: https://developers.facebook.com/docs/chat/ 下面是根据文档修改的类: <?php class Invite_Chat{ protect ...
- 解决weblogic页面和控制台乱码问题
转自:https://blog.csdn.net/u010995831/article/details/53283746 之前一直有碰到weblogic各种乱码问题,要不就是页面乱码,要不就是控制台乱 ...
- 查询及删除重复记录的SQL语句
1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select * from people where peopleId in (select peopleId from ...
- ASP.NET Core MVC 打造一个简单的图书馆管理系统 (修正版)(三)密码修改以及密码重置
前言: 本系列文章主要为我之前所学知识的一次微小的实践,以我学校图书馆管理系统为雏形所作. 本系列文章主要参考资料: 微软文档:https://docs.microsoft.com/zh-cn/as ...