使用tortoisesvn提交更新时,提示某个文件已过时,请更新工作副本

我在使用Tortoisesvn进行代码的版本管理,有时候在提交更新时,失败,提示:需要更新的代码已过时,请更新工作副本。后来发现是我更新的代码不是基于最新版本的代码修改的... 我在使用Tortoisesvn进行代码的版本管理,有时候在提交更新时,失败,提示:需要更新的代码已过时,请更新工作副本。后来发现是我更新的代码不是基于最新版本的代码修改的,而是在之前的某个版本上做的修改然后提交更新,就提示上诉错误。请问大家是怎么处理这个问题的,我经常需要返回到以前某个版本修改,而不是在最新的版本上修改,谢谢。 展开
 我来答
匿名用户
2013-03-31
展开全部
svn是采用一个服务器端和多个客户端的方式来进行版本管理的,每一个客户端都有自己的workcopy,即每个用户都可以取得文件的编辑权限。这样如果你和你的同事同时对一个文件做编辑(假设你们此时都是基于版本1做修改),如果你同事向服务器端提交的话,此时的版本为2,这样你提交的时候就会出现错误,因为你基于的版本1已经过期。解决办法有两个,一个是代码的merge功能(rapidsvn支持该功能),还有一种就是采用svn底层的lock机制的(默认不lock),你可以采用该机制来进行版本管理:当有人获取某文件的编辑权限时,服务器端上该文件被lock,这样其他用户都无法获取该文件的编辑权限,只有你释放权限(修改提交或者revert),别人才能获得编辑权限,也就是说你的文件将采取串行修改而非并行修改的方式(rapidsvn有详细的介绍,你可以去查查相关的资料,这个工具是开源的,应该很容易获取)
嵩山少侠来了

2020-11-05 · TA获得超过2.5万个赞
知道大有可为答主
回答量:1.2万
采纳率:0%
帮助的人:370万
展开全部
使用tortoisesvn提交更新时,提示某个文件已过时,请更新工作副本?问题在于,你进行提交的目录已经不是最新的版本。
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的。svn是采用一个服务器端和多个客户端的方式来进行版本管理的,每一个客户端都有自己的workcopy,即每个用户都可以取得文件的编辑权限。这样如果你和你的同事同时对一个文件做编辑(假设你们此时都是基于版本1做修改),如果你同事向服务器端提交的话,此时的版本为2,这样你提交的时候就会出现错误,因为你基于的版本1已经过期。解决办法有两个,一个是代码的merge功能(rapidsvn支持该功能),还有一种就是采用svn底层的lock机制的(默认不lock),你可以采用该机制来进行版本管理:当有人获取某文件的编辑权限时,服务器端上该文件被lock,这样其他用户都无法获取该文件的编辑权限,只有你释放权限(修改提交或者revert),别人才能获得编辑权限,也就是说你的文件将采取串行修改而非并行修改的方式(rapidsvn有详细的介绍,你可以去查查相关的资料,这个工具是开源的,应该很容易获取)
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
霜之咏叹调99
推荐于2017-10-07 · TA获得超过233个赞
知道小有建树答主
回答量:146
采纳率:0%
帮助的人:48.4万
展开全部
问题在于,你进行提交的目录已经不是最新的版本。
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式