SVN使用知识总结

一. SVN和Git区别

SVN : 集中式的版本控制工具
Git : 分布式的版本控制工具

二. SVN介绍

SVN最基本的命令使用及使用场景

要记得账号密码及SVN地址

  • checkout : 下载代码, 只需要做一次
  • commit : 提交代码到服务器, 至少下班前提交一次可运行版本
  • update : 更新服务器的最新代码, 至少上班前更新一次

三. SVN服务器搭建及配置(了解)

  1. 端口号
    http: 80 一般使用http即可。 一般只能在公司内部访问
    https: 443

  2. 服务器配置: 需要一个仓库, 然后创建一个用户, 最后给仓库配置权限

  3. 如何虚拟机搭建的服务器在mac中也能访问, (1. 网络模式是桥接模式, 2. 确保TCP/IP自动获取ip)

  4. 如果想要获取IP : 点击开始 –> 运行 –> 输入cmd –> ipconfig –> 确保前三位号段跟mac是一致的。

四. 常见UNIX命令行的使用(掌握)

  1. pwd :查看当前目录
  2. cat :在命令行中查看文件内容
  3. 显示和隐藏系统隐藏文件
显示隐藏文件:defaults write com.apple.finder AppleShowAllFiles YES
隐藏隐藏文件:defaults write com.apple.finder AppleShowAllFiles NO

运行完毕后需要重启finder,才能生效

五. SVN基本操作(掌握, 难点)

一. 模拟单人开发 –>唐僧

  1. cd 到唐僧目录下
  2. 下载代码: svn checkout http://192.168.26.120/svn/QQ/ –username=tangseng –password=123
  3. cd 到QQ目录下(QQ目录才是SVN管理的目录), 如果没有进入到正确的目录, 将来可能就会报错 –> 千万别忘
  4. 创建文件: (使用一个文件模拟一个项目) touch Person.h
  5. 查看状态: svn status / 比较的是本地版本库和服务器的版本库的区别, 如果文件一致, 比较不出来东西
  6. 添加文件到本地版本库: svn add Person.h
  7. 提交文件到远程服务器: svn commit -m “增加了Person.h” / 注意: -m 一定要写, 否则将来无法区分每个版本干了什么事. “”双引号的内容也要写, 而且要写的有意义, 因为将来就是根据注释来区分版本.
  8. 修改文件: 打开Person.h, 随便改内容
  9. 查看状态: svn status
  10. 同步代码 : svn update 就可以将服务器最新的代码同步过来
  1. 帮助命令: svn help 查看所有的命令
  2. 查看日志: svn log 查看之前提交的日志信息
  3. 删除文件: svn delete Car.h (如果是直接右键垃圾桶, update就回来了)
  4. 告诉本地版本库, 已经解决了冲突文件: svn resolved Car.h
  5. 版本回退(丢弃尚未提交的代码): svn revert Car.h

模拟多人开发 –> 其他人的操作
参考上面的单人开发步骤, checkout一次后, 不断提交/更新即可

二. 文件状态解释:

  • ? : 文件在SVN的目录下, 但是没有被本地的版本库管理 —> 需要add
  • A : 文件在SVN的目录下, 已经被本地的版本库管理 —> 需要commit
  • M : 文件在SVN的目录下, 已经被本地的版本库管理, 文件已经被修改 –> 需要commit
  • D : 本地的版本库已经删除了文件, 但是没有提交给服务器 —> 需要commit
  • U : 文件被更新了(之前本地已经有了这个文件)
  • C : 文件发生了冲突

三. 简写操作

  1. svn co : co –> checkout
  2. svn st : st –> status
  3. svn ci : ci –> commit * 可以不用写””, 但是要保证注释的文字的文字没有空格
  4. svn up : up –> update

四. 常见错误

  1. is not a working copy : 这不是工作区的拷贝空间, 进错目录了, 可以使用pwd查看当前目录是否正确
  2. is out of date : 文件过期了, 代表着文件发生了冲突. 需要update一下
  3. xcrun: error: active developer path (“/Applications/Xcode 2.app/Contents/Developer”) does not exist, use xcode-select --switch path/to/Xcode.app to specify the Xcode that you wish to use for command line developer tools (or see man xcode-select)
    **如果出现类似的错误, 或者下载xcode, 那么选中xcode–> 偏好设置–>locations–> command line tools 做个选择即可

五. 注意事项

  1. svn是mac自带的工具, 自带的版本是1.7
  2. 多提交多更新, 规范使用的话,应该先更新, 再提交. 可以减少冲突
  3. 已经是服务器的最新版本, 然后自己修改了某些文件, 再次更新, 不会覆盖掉自己刚写的代码

六. 解决代码冲突(掌握, 重点, 难点)

  1. 冲突的定义: 不同的人, 修改了同一个文件, 同一行的代码, 那么此文件就发生了冲突

  2. 冲突可能发生地方: Appdelegate, MainViewController, SB/Xib, 公用的类

  3. 冲突发生时如何处理
    Conflict discovered in ‘/Users/JackMeng/Desktop/SVN演练/coder01/QQ/person.h’.

  • (p) postpone : 推迟处理, 将来由程序员自己来处理冲突
  • (mc) mine-conflict : 使用我的代码, 覆盖掉其他人的代码 –> 文件已经被修改了, 需要提交
  • (tc) theirs-conflict : 使用其他人的(服务器最新的), 丢弃掉自己的代码
  • (df) diff-full : 展示不同
  • (e) edit : 在命令行中编辑文件
  • (s) show all options: 显示所有选项

<<<<<<< .mine 到 ======= 之间: 代表自己写的代码
======= 到 >>>>>>> .r6 之间: 服务器的代码(其他人的代码)

<<<<<<< .mine
@property (nonatomic, copy) NSString *rice2; // 唐僧增加了米饭2属性
@property (nonatomic, copy) NSString *rice3; // 唐僧增加了米饭3属性
=======
@property (nonatomic, copy) NSString *rice2; // 唐僧增加了米饭2属性
@property (nonatomic, copy) NSString *peach; // 悟空增加了桃子属性
>>>>>>> .r6
  1. 建议一般情况遇到冲突, 选postpone
    1. 输入p
    2. 删除掉特殊符号(< = >), 然后自己调整代码
    3. 需要告诉本地版本库, 已经解决了冲突: svn resolved Car.h
    4. 提交修改的代码

七. 使用第三方图形化工具(掌握, 重点)

小技巧, 拷贝网址后, 再次点击Cornerstone会自动将网址填入正确的位置

  1. 工具使用的步骤:

    1. 首先需要使用账户密码以及ip来登录远程仓库
    2. 使用checkout命名来下载代码
    3. 按照需求, 使用界面上的不同按钮即可
  2. 工具解决代码冲突

    1. 删除掉特殊符号(< = >), 然后自己调整代码
    2. 需要告诉本地版本库, 已经解决了冲突:点击工具下方的resolve按钮即可
    3. 提交修改的代码
  3. 忽略文件的问题:
    Xcode在创建时, 有些文件是记录用户的状态(缓存文件), 这些文件是可以忽略的.
    包括了用户当前打开的是哪个文件/文件夹的折叠状态/用户打的调试断点, 等等

  4. 哪些文件可以忽略: .xcuserstate / data文件夹内东西都可以忽略.

  5. 如何使用工具删除忽略文件:

    1. 选中文件夹/文件, 右键 –> delete , 删除之后再提交
    2. 文件只要发生更改, 会再次生成, 选中之后 –> ignore, 忽略后再提交

八. 使用Xcode集成SVN(掌握, 重点)

  1. Xcode如何checkout

    1. 通过xcode –> preferences —> Accounts界面 (繁琐,不推荐)
    2. xcode的欢迎界面, 选择最底下的checkout选项, 输入完整的地址, 然后输入账户名和密码, 并且选择的时SVN控制方式, 确定即可
    3. 选中xcode, 找到顶部的source Control –> 选择checkout即可
  2. 两个快捷键

    1. 提交 : com + opi + c
    2. 更新 : com + opi + x
  3. Xcode解决代码冲突

    1. 先update, 只要文件发生了冲突, 会出现一个选择界面, 想要解决冲突, 那么应该看情况选择下方的四个小按钮. 选择完成, 点击update
    2. 提交解决冲突后的文件即可
  4. XcodeSB/Xib冲突, 不要发生SB和Xib的冲突.

  5. 如何避免冲突的

    1. 做好分模块开发的操作
    2. 勤沟通, 提交说好, 一个人改的时候, 别的不要动.
    3. 及时将不需要提交的代码丢弃修改

九. SVN目录结构

  1. trunk : 主干, 一般都在此目录下工作
  2. brangches: 分支, 一般用于修复bug, 或者开发新功能 (SVN中不常用)
  3. tags : 备份用的, 可以将发布到AppStore的版本做备份, 方便将来查找修改等
    原文作者:奋斗的蜗牛
    原文地址: https://www.jianshu.com/p/9debf6f58575
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞