svn update原理

svn update是这样计算的

  1. 当你的文件处于最新版本,且文件内的修改 新于 版本时间,那么update将无效(没有任何效果)
  2. 当你的文件处于非最新版本,且有修改内容 与 版本库不冲突(或者svn可以解决的冲突)update能够正常使用,而且保留你的修改内容,并使得版本库的修改也更新进来。回到 1 状态
  3. 当你的文件处于非最新版本,且冲突无法解决,svn返回 C 也就是冲突状态,那么你就默默解决冲突吧

Git 和svn对比

  • git版本库占用空间小;
  • git是分布式管理系统,完全可以不对代码进行备份;
  • git不用时时联网查询;
  • 如果客户端离服务器端非常远,在网速糟糕的情况下,用svn下载代码速度远不上git。
  1. git版本库占用空间小,SVN每个分支都是一份代码的copy,而git每个分支只是各个提交点的hash值的集合。分支几乎不占用什么空间。
  2. git是分布式管理系统,完全可以不对代码进行备份,但SVN不行,一旦服务器的硬盘挂掉整个代码库就完了。
  3. git不用时时联网查询,并且对文件进行压缩,使得文件体积大大减小,并且传输速度快,svn是单个文件,git是压缩后的,在使用svn时我已经碰到过好几次服务器无响应了。由于git很多都可以在本地操作的,所以大大降低了客户端对服务器的连接,出现这种情况的概率会大大减小。

SVN trunk(主线) branch(分支) tag(标记) 用法详解和详细操作步骤

使用场景:

假如你的项目(这里指的是手机客户端项目)的某个版本(例如1.0版本)已经完成开发、测试并已经上线了,接下来接到新的需求,新需求的开发需要修改多个文件中的代码,当需求已经开始开发一段时间的时候,突然接到用户或测试人员的反馈,项目中有个重大bug需要紧急修复,并且要求bug修复后要立即上线;此时应该怎么修复bug呢?

继续阅读“SVN trunk(主线) branch(分支) tag(标记) 用法详解和详细操作步骤”

Svn 和git 同时使用

已经是git仓库情况

1、svn checkout

2、svn status 查看状态,会有许多删除冲突

3、使用revert命令恢复 svn revert ./* -R [或者单独文件 R递归]

4、再次查看状态,删除冲突消失

5、git pull ,git reset –hard 清除svn的更改,然后查看git 和svn状态是否正常,

6、修改,往两处提交就可以了

此过程可能需要多次gc cleanup

1 Svn checkout

2 git pull

3 换行符问题

4 git 修改为 autocrlf

5 Add 提示有些lf转换问题

6 再改为autocrlf false

7 再次add

腾讯云图