SVN提交代码冲突解决方法总结
在近期svn提交代码时遇到多种情况的问题,现做一个解决办法的总结如下:
插播一条:idea下被svn版本控制各类文件的颜色区分,
红棕色,未加入版本控制;
绿色,已经加入控制暂未提交;
蓝色,加入,已提交,有改动,与版本库文件不一致;
黑色,加入,已提交,无改动,和版本库文件一致;
灰色:版本控制已忽略文件。
1.内容冲突:当两名(或更多)开发人员修改了同一个文件中相邻或相同的行时就会发生文件冲突。
(1)修改同一文件不同位置引发的冲突,其他人在你之前提交了代码
你提交时报错:该文件已经过期,需要先更新文件
解决办法:点击update更新该文件代码,在此基础上添加自己更改的部分,再次提交,成功。
(2)修改同一文件相同位置引发的冲突
你提交时报错:

点击update更新该文件版本,提交,再次报错:

解决办法:与其他人协商,根据冲突部分代码逻辑,选择你的或者别人的代码。
2.树冲突:当一名开发人员移动、重命名、删除一个文件或文件夹,而另一名开发人员也对它们进行了移动、重命名、删除或者仅仅是修改,在更新时就会发生树冲突。
(1) 本地删除,外部更改
A(外部) 修改文件并将其提交至版本库中
B (本地)同时删除了文件
B 更新时就会发生树冲突,该文件被标记为冲突,B 的解决方法有:
- 放弃 A (外部)更改:也就是删除这个文件----直接标记冲突为已解决。
- 放弃 B (本地)删除:选择取消,右键 TortoiseSVN --> SVN 还原,撤销删除操作。
(2)本地改名,外部更改
A(外部) 修改文件,并将其提交至版本库中。
B (本地)同时将文件改名。
B 更新时, 该文件被标记为树冲突,B 的解决方法有:
- 合并 A (外部)更改到改名后的文件中去:直接选合并修改(见下图)----> 标记冲突为已解决,然后提交。
- 放弃 A 的更改:改名后的文件不包括 A 的更改内容 ----> 直接标记冲突为已解决,然后提交,
- 放弃 B 的改名:选择取消,TortoiseSVN --> SVN 还原,撤销改名操作。
(3)本地更改,外部删除
A(外部)删除了文件,并提交到了版本库;
B(本地)同时对该文件进行了修改。
B 更新时,该文件被标记为树冲突,B 的解决方法有:
- 放弃 A(外部)的删除:不删除文件,同时保留本地内容修改---->直接选保留本地文件,然后提交;
- 放弃 B(本地)的更改:直接选删除此文件。
(4)本地更改,外部改名
A(外部)将文件改名,并提交到了版本库;
B(本地)修改了文件内容。
更新时,B 的该文件被标记为树冲突,B 的解决方法有:
- 合并更改到改名后的文件:选择保留本地文件,手动将更改内容移植到改名后的文件,撤销增加原文件,然后提交。
- 放弃 A(外部)改名:选择保留本地文件,然后删除改名后的文件,然后提交。
- 放弃 B(本地)更改:文件改名,内容不变-->直接选删除此文件。
(5)本地删除,外部改名
A(外部)将文件改名,然后提交到版本库;
B(本地)将文件删除。
更新时,B 的该文件将发生树冲突,B 的解决方法有:
- 接受 A 的改名:标记冲突已解决;
- 坚持删除文件:把改名后的文件删除,然后提交。
(6)本地改名,外部删除
A(外部)将文件删除,然后提交到版本库;
B(本地)将文件改名。
更新时,B 的该文件将发生树冲突,B 的解决方法有:
- 接受 A 的删除:标记冲突已解决,然后撤销增加改名后的文件;
- 坚持改名:标记冲突为已解决,然后提交。
(7)本地改名,外部改名
A(外部)将文件改名,并提交到版本库;
B(本地)将同文件改名。
更新时,B 的该文件将发生树冲突,B 的解决方法有:
- 用 A 的名字:标记冲突为已解决,撤销增加本地改名后的文件;
- 用 B 的名字:标记冲突为已解决,删除 A 改名后的文件,然后提交。
3.总结:对症下药,拒绝盲目反复提交
SVN代码提交减少冲突的方法无非两种:
- 避免开发人员同时开发同一文件
- 开发前需要时常更新本地代码库
SVN提交代码冲突解决方法总结的更多相关文章
- svn提交遇到冲突解决方法
冲突:如果提交时候发现冲突了先不急着提交,否则会产生冲突文件. 解决步骤: 1.将本地文件先复制一份 2.svn revert(恢复到没修改前版本) -> svn update(更新当前最新版本 ...
- git 本地与远程仓库出现代码冲突解决方法
提交过程中报错: [python@heaven-00 Selesystem]$ git push -u origin masterUsername for 'https://github.com': ...
- mac下svn提交失败的解决方法
$svn ci maps.xml然后出现一个文件svn-commit.4.tmp,在文件svn-commit.4.tmp中有如下内容: --This line, and those below, ...
- svn提交报错 解决方法
1.先clean 2.删除 .lock文件 3.update项目 4.先还原文件,然后update 接着commit
- git提交代码冲突解决
1.git stash save "说明信息" 2.git stash lish 3.git pull 4.git stash pop stash@{编号}
- 【技术贴】解决myeclipse SVN 提交代码 commit:remains in tree-conflict错误的解决办法
[技术贴]解决myeclipse SVN 提交代码 commit:remains in tree-conflict错误的解决办法 错误是:Aborting commit: xxxxx’ remains ...
- 【技术贴】解决myeclipse SVN 提交代码 commit:remains in tree-c
[技术贴]解决myeclipse SVN 提交代码 commit:remains in tree-conflict错误的解决办法 错误是:Aborting commit: xxxxx' remains ...
- SVN系列操作(二)&svn不显示图标的解决方法
接着上一篇文章,我们继续来操作一下SVN: 有同学反馈,我在本地上看到不SVN的图标,先解决一下这个问题. svn不显示图标的解决方法: 1.WIN+R,输入regedit,打开注册表 2.找到HKE ...
- svn 提交代码报错
svn 提交代码报错 最近新安装了TortoiseSvn 1.92,在上传代码,其中有新增加的文件,出现如下错误: 解决方法: 1.用vs生成patch文件 2.生成的patch文件中讲nonexis ...
随机推荐
- Codeforces_764_C. Timofey and a tree_(并查集)(dfs)
C. Timofey and a tree time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- MFC_2.5 选项卡控件的使用
选项卡控件的使用 1.新建默认MFC文件. 2.资源-添加Dialog-添加类.(假设生成3个,Dialog1Dialog2Dialog3) 3.类向导,添加类,点小三角形,添加MFC类.添加CTab ...
- 【Linux】Tomcat安装及端口配置
安装环境 :Linux(CentOS 64位) 安装软件 : apache-tomcat-9.0.20.tar.gz(下载地址http://tomcat.apache.org/) 一:JDK安装配置 ...
- 分析器错误消息: 该配置节不能包含 CDATA 或文本元素。
原因当然是web.config配置文件中,有字符串文本了,估计不小心加上的一些字符,所以会报错,去掉就行,例如13行的s
- 比较常见的几种代理ip类型
1.HTTP代理服务器 代理服务器英文全称是Proxy Server,他的功能就是代理网络用户去获得网络信息.形象点说:就是网络信息的中转站.通常情况下,网络浏览器直接去连接其他Internet站点取 ...
- Redis系列(三)--消息队列、排行榜等
Redis命令执行生命周期: 发送命令--->排队(单线程)--->执行命令--->返回结果 慢查询: 只是针对命令执行阶段 慢查询日志通过一个固定长度的FIFO queue,这个q ...
- [转]SSD固态存储大观(一)
From: http://blog.51cto.com/alanwu/1405874 Contents 1.概述... 1 2.FusionIO:Pcie SSD的始作俑者... 2 3.Intel ...
- Listview异步加载图片之优化篇
在APP应用中,listview的异步加载图片方式能够带来很好的用户体验,同时也是考量程序性能的一个重要指标.关于listview的异步加载,网上其实很多示例了,中心思想都差不多,不过很多版本或是有b ...
- Many Equal Substrings CodeForces - 1029A (kmp next数组应用)
题目大意 题目看样例也能猜到就是输出最短的循环串. 吐槽 明明是div3第一题为啥子还会用到kmp的知识? 解法 这个题仔细看发现是求最长可去除的后缀,也就是说去除跟下一个相同的字符串还能连接起来.这 ...
- Ubuntu下安装oh-my-zsh
本文参考 https://www.jianshu.com/p/9a5c4cb0452d 此文已在ubuntu下确实安装成功,只不过懒得截图了,可以参照上述地址,我在他原基础上进行了一些更改. 安装Oh ...