一、git对比svn有什么优势?
Subversion是集中式管理的数据仓库
虽然速度快和多副本等git分布式数据仓库显而易见的好处吸引了很多人的喜爱,但在很多情况下,一个集中式的数据仓库却是更合适的。例如,如果你有一些核心代码想只允许部分人能访问,把它放到git里必然是你不希望的。很多的企业都是将它们的代码集中管理的,我猜,所有(重要)政府项目估计都使用的是集中式数据仓库的版本控制系统。
Subversion的理念符合常规思维这是说,很多人(特别是管理者或老板)对版本号有一种习惯的认识,把开发视作一种按时间的线性发展轨迹,这在他们脑子里根深蒂固。并不是找借口,Git的随意性并不是很容易去理解,你也许注意到了,任何一本关于Git的书都会在第一章第一节告诉你要抛弃脑子里所有的传统观念,重新认识。
Subversion只提供一种途径,没有第二选择
SVN是一个版本控制系统,它只提供一种方式做这些,每个人都使用相同的方法。就是这样。这使得你将代码从SVN迁移到其它集中式管理的VCS或从其它集中式管理的VCS迁进来变得很容易。Git并不仅仅是一个版本控制系统——它实际上是一个文件系统,它里面有很多的拓
扑学知识来支持你如何在不同的环境中架设代码仓库——并且没有一个统一的标准。选择一个合适的拓扑结构就成了难题。
其它一些优势:
SVN支持空目录
SVN有更好的Windows平台支持
SVN可以check out/clone一个子树(sub-tree)
SVN支持特权访问控制svn lock,在处理很难合并的文件时非常有用
SVN支持二进制文件,更容易处理大文件(不需要把老版本拷来拷去)
提交文件相对简单,因为没有pull/push操作,本地修改通过svn update自动的执行了同步代码的功能。
------------
二、svn用reintegrate合并代码时,代码为什么会乱码?
解决办法: 用svn档案库浏览器打开报错的svn地址,比如上边的,"Missing ranges: /xxx/xxx/src/com/xxx/xxx/action/TestAction.java:4210-4215",就用版本库浏览器找到这个文件,然后在这个文件上右键->显示属性,然后会看到Property下有一个svn:mergeinfo,点击下边的删除或者Remove按钮,删掉这个.再去合并,就好了.需要注意的是,你要合并的文件夹,下边一定任何一个文件的属性都不能有这个.不然就合并不成功.一般跟着svn报错的提示都可以找到有svn:mergeinfo的属性. 删除之后,还要update一下myeclipse上的代码.才能让文件的属性更新到本地的文件中,才能进行合并.
三、svn如何设置svn:ignore?
还没有纳入SVN控制的文件,才能将其加入忽略列表。已经被SVN控制的文件,不能直接加入忽略列表,所以你那项菜单是灰色的,你可以把这个文件或文件夹导出(export)另存,在原本地工作区中删除这个文件或文件夹,并commit,然后再把导出的文件复制回来,这时复制回来的文件就不受SVN控制了,你就可以对它设置加入忽略列表。
四、svn提示svn: warning: '.' is not a working copy?
那是因为你后面的参数没有跟对,svn log 和 svn status后面如果不跟上SVN库的url时,默认是查当前文件夹的svn日志和状态,如果你当前文件夹不是一个checkout出来的SVN客户端文件夹,自然就会报这个错了。
“.”代表的是当前文件夹,那句报错意思是说当前文件夹不是一个工作副本(即SVN客户端文件夹)。
所以,你要么是checkout出来一个工作副本,然后cd命令将当前文件夹切到工作副本,然后svn log;要么是svn log 后面加上url参数
五、svn算法?
svn是一个开放源代码的版本控制系统,它管理着随着时间改变的数据,这些数据存放在一个中央资料档案库中。这个档案库很像一个普通的文件服务器,不过它会记住每一次文件的变动。这样你就可以把档案恢复到旧版本,或是浏览文件的变动历史。
1、SVN简介
· repository:源代码库,源代码统一存放的地方。
· Checkout:提取,我们可以从源代码库提取代码。
· Commit:提交,当修改了代码,我们可以提交到源代码库。
· Update:更新,当提取了一份源代码,更新一下就可以和代码库中的源代码同步。
如果两个程序员同时修改了同一个文件,SVN可以合并这两个程序员的改动。SVN管理源代码是以行为单位的,两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN会提示文件冲突,需要手动确认
六、svn原理?
svn是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据。
这些数据放置在一个中央资料档案库 中。
这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。
这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。
svn的一些概念
repository(源代码库):源代码统一存放的地方;
Checkout(提取):当你手上没有源代码的时候,你需要从repository checkout一份;
Commit(提交):当你已经修改了代码,你就需要Commit到repository;
Update (更新):当你已经Checkout了一份源代码,Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更。
七、IntelliJ IDEA怎么配置svn,集成svn方法?
首先需要下载一个 svn的客户端,可以到这里下载对应的安装程序:http://subversion.apache.org/packages.html#windows
我是用的是TortoiseSVN(小乌龟),下载后安装 ,然后记住安装路径,我安装的是64位的。
TortoiseSVN的下载地址 : https://tortoisesvn.net/downloads.html
在安装svn客户端的时候一定要勾选,否则在idea上集成svn的时候会找不到 svn.exe 而报错。
如果安装时忘记勾选了的话,安装包重新运行,选择modify,然后勾选command line client tools项就行了。
报错信息:
安装好svn客户端后,想启用idea的SVN插件还需要在idea配置一下,file - setting 按钮打开设置界面 或者(Ctrl + Alt + S)快捷键 ,如下图所示:
重启一下你的IntelliJ Idea,然后从svn库中下载项目:
输入公司的svn的地址check 出你想要的项目,就OK了
八、svn更新时报错Please execute the 'Cleanup' command.+乱码。clean up失败,求大神~?
用dos命令进入项目文件夹,运行svn cleanup;不要直接右键点击找cleanup选项
九、svn开源吗?
svn是开源的。
SVN是subversion的缩写,是一个开放源代码的版本控制系统,通过采用分支管理系统的高效管理,简而言之就是用于多个人共同开发同一个项目,实现共享资源,实现最终集中式的管理。
SVN的客户端有两类,一类是基于Web的WebSVN等,另一类是以Tortoise SVN为代表的客户端软件。前者需要Web服务器的支持,后者需要用户在本地安装客户端,两种都有免费的开源软件供使用。
十、svn未响应?
检查你的SVN路径是否正确。正确路径示例:svn://ip/(svn://1.1.1.1/)
确保SVN路径正确,那就是可能SVN服务没启。需要重新启动SVN服务。用SVN用户登录。然后执行命令:svnserve -d -r /home/svn/svn项目路径
- 相关评论
- 我要评论
-