项目优化经验分享(六)SVN冲突和处理
上一篇博客我们分享了新增需求的确定思想《站在全局看问题》。今天我们来分享项目开发中SVN冲突的解决经验:SVN冲突和处理!
引言
开发过项目的人都知道,公司开发一个项目都会使用到版本号控制工具,版本号控制工具非常多,比方Clear case,CVS,Visual
SourceSafe,SourceAnywhere ,StarTeam,SVN,CVS,GIT等等,有的是元老级开发工具,有的是后起之秀,各种版本号,百花齐放,这篇博客我们将要谈到的则是经常使用版本号控制工具:SVN的冲突和处理。
实例
1.冲突产生
如果A、B两个用户都在版本号号为1000的时候,更新了practice.txt这个文件,A用户在改动完毕之后提交practice.txt 到server,这个时候提交成功,然后practice.txt文件的版本号号已经变成1001了。同一时候B用户在版本号号为1000的practice.txt文件上作改动,改动完毕之后提交到server时,因为不是在当前最新的1001版本号上作的改动,所以导致提交失败。
冲突发生时,subversion会在当前工作文件夹中保存全部的目标文件版本号[上次更新版本号、当前获取的版本号(即别人提交的版本号)、自己更新的版本号、目标文件]。
(1)如今A、B两个用户都更新practice.txt文件到本地。
(2)文档中原始文件内容例如以下:
(3)A用户改动文件,加入内容“A用户改动-提交”完毕后提交到server
(4)B用户改动文件,加入内容“B用户改动-提交”完毕后提交到server
(5)B用户提交更新至server时提演示样例如以下:
B用户将文件提交至server时,提示版本号过期:首先应该从版本号库更新版本号,然后去解决冲突,冲突解决后要运行svn resolved(解决),然后在签入到版本号库。在冲突解决之后,须要使用svn resolved(解决)来告诉subversion冲突解决,这样才干提交更新。
2.冲突处理
方法一:放弃自己的更新,使用svn Revert(回滚),然后提交。
当使用svn revert时不须要再用svn resolved来删除暂时文件了,由于撤销会恢复全部的文件到改动前,除了已删除的文件。
方法二:放弃自己的更新,使用别人的更新。使用最新获取的版本号覆盖目标文件,运行resolved filename并提交(选择文件—右键—解决);
方法三:手动解决,冲突发生时,通过和其它用户沟通之后,手动更新目标文件。然后运行resolved filename来解除冲突,最后提交。
(1)手工合并冲突文件:当查看了详细出冲突的文件后,能够打开该文件,找到冲突的标志。
Top piece of bread
Mayonnaise
Lettuce
Tomato
Provolone
<<<<<<< .mine
Salami
Mortadella
Prosciutto
=======
Sauerkraut
Grilled Chicken
>>>>>>> .r2
Creole Mustard
Bottom piece of bread
小于和大于符号之间的就是冲突的地方,假设有能力在改动完文件而且删除冲突标志之后,进行svn resolved来删除三个暂时文件
注:假设改动时不是非常明确,能够參考冲突时的三个文件
(2)复制某一工作文件(一般用的不是非常频繁):假设仅仅是希望取消本次的改动,你可拷贝svn为你生成的文件替换你的工作拷贝
$ svn update
C practice.txt
Updated to revision 2.
$ ls
practice.*
practice.txt
practice.txt.mine
practice.txt.r2
practice.txt.r1
$ cp
practice.txt.r2
practice.txt(这里r2是版本号库里你此次更新前的版本号文件)
$ svn resolved
practice.txt(用来删除三个暂时文件)
OK!冲突解决!
提交更新!
总结
有时候冲突是不可避免的,可是我们能够尽量减少冲突的复杂度,详细解决方案有:
1、当文档编辑完毕后,尽快提交,频繁的提交/更新能够减少在冲突发生的概率,以及发生时解决冲突的复杂度。
2、在提交时,写上明白的message,方便以后查找用户更新的原因,毕竟随着时间的推移,对当初更新的原因有可能会遗忘。
3、养成良好的使用习惯,使用SVN时每次都是先提交,后更新。每天早上打开后,首先要从版本号库获取最新版本号。每天下班前必须将已经编辑过的文档都提交到版本号库。
项目优化经验分享(六)SVN冲突和处理的更多相关文章
- 项目优化经验分享(八)TeamLeader经验总结
引言 通过前面的七篇博客.我把自己在项目优化过程的经验进行了分享,今天这篇博客,作为一个总结,就来讲讲作为一个TeamLeader,在项目管理中遇到的问题和解决经验! 正文 问题一:团队之间怎么沟通? ...
- Visual Studio 2015开发Qt项目实战经验分享(附项目示例源码)
Visual Studio 2015开发Qt项目实战经验分享(附项目示例源码) 转 https://blog.csdn.net/lhl1124281072/article/details/800 ...
- Lucene底层原理和优化经验分享(1)-Lucene简介和索引原理
Lucene底层原理和优化经验分享(1)-Lucene简介和索引原理 2017年01月04日 08:52:12 阅读数:18366 基于Lucene检索引擎我们开发了自己的全文检索系统,承担起后台PB ...
- Unity MMORPG游戏优化经验分享
https://mp.weixin.qq.com/s/thGF2WVUkIQYQDrz5DISxA 今天由Unity技术支持工程师高岩,根据实际的技术支持工作经验积累,分享如何对Unity MMORP ...
- 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享四:部署到阿里云
框架: SpringBoot+Mybatisplus+Shiro 简单介绍:关于写SpringBoot+Mybatisplus+Shiro项目的经验分享一:简单介绍 阿里云开放必要端口,mysql与t ...
- 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享三:问题2
框架: SpringBoot+Mybatisplus+Shiro 简单介绍:关于写SpringBoot+Mybatisplus+Shiro项目的经验分享一:简单介绍 搜索框是该项目重要的一环,由于涉及 ...
- 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享二:问题1
框架: SpringBoot+Mybatisplus+Shiro 简单介绍:关于写SpringBoot+Mybatisplus+Shiro项目的经验分享一:简单介绍 添加时,如果失败,不能正确跳转 c ...
- Unite Europe案例项目《影子战术》层级优化经验分享
http://forum.china.unity3d.com/thread-25087-1-9.html 在Unite Europe 2017的Keynote主题演讲中,我们为大家分享了将主机游戏&l ...
- Unity技术支持团队性能优化经验分享
https://mp.weixin.qq.com/s?__biz=MzU5MjQ1NTEwOA==&mid=2247490321&idx=1&sn=f9f34407ee5c5d ...
随机推荐
- 在Outlook中设置QQ邮箱
原本以为在Outlook中设置QQ邮箱没多大难度,但我错了,估计错了腾讯的麻烦程度,故记录下来. ----- 打开Outlook 2013(Outlook 2010也差不多),若是第一次打开会提示你设 ...
- C语言程序转换为Python语言
python语言是支持用c来它写模块的,其实现有的很多模块也是用c写的.这里我做个简单的介绍. 先决条件:1.在linux上编写,需要自己编译出python的动态连接库.也就是要有libpython2 ...
- Java InputStream读取网络响应Response数据的方法
Java InputStream读取数据问题 原理讲解 1. 关于InputStream.read() 在从数据流里读取数据时,为图简单,经常用InputStream.read()方法.这个方 ...
- Windows Phone 8初学者开发—第2部分:安装Windows Phone SDK 8.0
原文 Windows Phone 8初学者开发—第2部分:安装Windows Phone SDK 8.0 原文地址:http://channel9.msdn.com/Series/Windows-Ph ...
- 隐藏APK在Launcher中的启动图标 android开发教程
隐藏APK在Launcher中的启动图标: APK的AndroidManifest.xml文件的主Activity中删除 intent-filter 中的 <category android:n ...
- Android zip文件压缩解压缩
DirTraversal.java <P style="TEXT-ALIGN: left; PADDING-BOTTOM: 0px; WIDOWS: 2; TEXT-TRANSFORM ...
- sublime2/3自总结经常使用快捷键(2的居多)
Ctrl+D 选词 (重复按快捷键,就可以继续向下同一时候选中下一个同样的文本进行同一时候编辑) Ctrl+鼠标左键 能够同一时候选择要编辑的多处文本 Shift+鼠标右键(或使用鼠标中键)能够用鼠标 ...
- ThinkPHP - 独立分组项目搭建
配置文件: <?php return array( //独立分组 'APP_GROUP_LIST' => 'Home,Admin', //分组列表 'APP_GROUP_MODE' =&g ...
- BZOJ 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱( dp )
dp( l , r ) = sum( l , r ) - min( dp( l + 1 , r ) , dp( l , r - 1 ) ) 被卡空间....我们可以发现 l > r 是无意义的 ...
- Android空指针异常的常见情况
把我经常遇到的nullpoitException写在这里,以便以后自己查找原因. 1.用findViewById(param )的方法获取一个view对象的时候,有的时候其实应该是获取一个layout ...