SVN更新代码的时候会覆盖本地文件吗?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SVN更新代码的时候会覆盖本地文件吗?相关的知识,希望对你有一定的参考价值。

参考技术A

    不会覆盖的。

    如果远程代码变更与你本地的修改没有冲突,就不会有什么问题,如果远程代码与你的修改有冲突是不会直接覆盖你本地的修改的。

    它会问你怎么去处理冲突,是采用本地的还是远程的。所以一般不用担心会被覆盖。

    svn比较cvs来说,有个好处是多个人可以同时对同一个文件进行修改,并同时提交。
    服务器会自动记录这些变动。

    如果碰巧两个任修改的是同一行代码,那么svn会用颜色分别标注出每个人的修改。

知识小结PHP使用svn笔记总结

在公司里,我们要养成每天上班前更新代码,下班前提交代码的习惯,并且做好说明。

svn更新代码的时候,先右键点击需要更新的项目,在team中进入资源库同步界面,选择incoming mode,显示的文件是需要更新的,

黑色向右箭头  :本地修改过的文件(可以选择提交,或者覆盖/更新-就是把本地修改覆盖掉)

蓝色向左箭头 :SVN服务器端修改过的文件--需要更新
黑色向右且带加号的箭头 :本地比服务器端多出的文件--选择提交或删除
蓝色向左且带加号的箭头 :服务器端比本地多出的文件--更新
黑色向右且带减号的箭头:本地已经删除,而服务器端没有删除的文件--同步
蓝色向左且带减号的箭头:服务器端已经删除,而本地没有删除的文件--同步库
红色双向箭头 :本地和服务器端同时修改过的文件--先比较,然后把服务器新增的添加过来,选择合并,然后再提交
黑色带星号的图标  :本地已经修改过但是没有提交的文件
工作前先更新代码,提交前原则也是先更新,因为有可能在你编写代码这个过程中资源库有变化。
出现项目带红叉时,恢复到资源库最新内容的版本

Eclipse中SVN客户端的基本操作:

同步(Synchronize):同步,是在更新提交之前做的工作,更新提交前先同步,可以知道哪些东西要提交哪些东西要更新,哪些东西是冲突的(你和同事 改了同一个文件,可能会出现冲突),出现冲突不能提交也不能更新,只有先将冲突的文件选择用本地的文件覆盖或用服务器的文件覆盖本地后才能更新或提交,具体的用法还需要楼主多实践。右击项目、目录或者文件→Team(小组)→Synchronize(与资源库同步),会进入同步视图界面,这里会显示所选择的项目或者目录中与资源库(SVN服务器端)相比做过修改的文件,或者所选择的文件是否被修改过,双击文件能显示文件中具体的不同之处。

提交(Commit):提交,是指服务器上没有的,也就是你改过的东西,你需要将代码提交,其他同事更新你的代码。在同步视图中右击文件选择“提交(Commit)”,或者在项目视图中右击项目、目录或者文件→Team(小组)→Commit(提交),可以将本地的文件提交到SVN服务器端。


更新(Update): 更新,是指服务器上变动了的,而你本地没有变动,需要你更新。在同步视图中右击文件选择“更新(Update)”,或者在项目视图中右击项目、目录或者文件→Team(小组)→Update(更新),可以将SVN服务器端的文件更新到本地,使本地文件与服务器端保持版本一致。

原则上是先更新,后提交。


以下是商务合作



不然他不一定给你通过吧,只能提醒到这了。


以上是关于SVN更新代码的时候会覆盖本地文件吗?的主要内容,如果未能解决你的问题,请参考以下文章

强制 SVN 更新/签出覆盖本地文件

svn,在更新时,如何实现覆盖原有的文件,而不是在文件中多了几道杠,和很多重复代码

svn 的重新定位之后,本地代码会被新服务器上面的代码覆盖吗

知识小结PHP使用svn笔记总结

SVN 我刚刚用SVN覆盖更新了我本地的代码,悲催的是,我有一些新写的代码忘记提交了,直接被覆盖了!!!!

SVN 我刚刚用SVN覆盖更新了我本地的代码,悲催的是,我有一些新写的代码忘记提交了,直接被覆盖了!!!!