好用的Windows下SVNclient——Tortoise SVN的下载地址:

http://tortoisesvn.tigris.org/

文档:

http://www.subversion.org.cn/svnbook/

http://www.subversion.org.cn/tsvndoc/

SVN 与 VSS 的差别:

VSS中,编辑一个文件,有一个锁定的概念,这样能够确保改动一个文件时别人无法改动这个文件

SVN和它思路不同,SVN中觉得,项目中的參与人员,一般来说,分工明白的情况下编辑并不会冲突,所以并不特别重视锁定这个概念(可是SVN全然支持相似于VSS的锁定,独占一个文件的编辑)

即使编辑了一个文件,仅仅要不是同一行,SVN还拥有很智能的方式将它们合并进成为一个新的文件

仅仅有在编辑了同一个文件的同样位置,SVN才会把文件标记为冲突,从而交给用户进行处理

TortoiseSVN(以后简称TSVN)使用:

全部操作,大部分操作在右键菜单的TSVN中,

后文中提及的大部分操作,

都是右键菜单操作。

正文

之中的一个:建立SVN项目仓库

你也能够在自己的计算机建立SVN的仓库

方法是:

新建一个目录,比方d:svnmyproject

进入这个目录,右键->TSVN->Create repository here...

然后在你的项目目录(比方e:javamyproject1)里面导入项目:

进入e:javamyproject1,然后右键,TSVN->Import

输入:file://d:/svn/myproject/trunk

导入即可了

SVN支持http://, svn://, file://等多种协议

它本身(非TSVN,TSVN不过client)能够作为server执行,也能够作为apache的模块执行

以后你在e:javamyproject1以下的提交之类的操作将会被记录在d:svnmyproject这个仓库里面

之二:下载项目仓库文件到工作文件夹:

如今,新建一个空目录

使用刚建好的SVN项目仓库地址(比方:file://d:/svn/myproject/trunk

右键空白处

选择SVN Checkout(检出)

之三:提交改动的文件

右键->SVN Commit

会出现一个提交窗体,Message里面写入关于这次提交的一个概要

这里我们进行一个约定

假设这次的提交以改动为主,那么Message前面加上@MOD,比方:

"@MOD 对README.txt进行了改动,增加了项目描写叙述"

诸如此类

假设这次提交以加入新文件为主

那么@ADD,比如:

"@ADD 增加style.css样式表"

这是test项目,你能够任意编辑,任意提交,任意删除

可是不要删除不论什么的隐藏的.svn目录以下的内容,这个是SVN的信息

重命名是,右键文件->TSVN->Rename

删除是,右键文件->TSVN->Delete

凝视:

  1. 锁定:锁定一般针对二进制文件编辑时採用,比方jpg, gif, doc之类的非纯文本文件
  2. 版本:SVN中,不论什么提交,不管改动有多么微小,都会让修订版本添加1
  3. ShowLog:右键空白处->TSVN->Show Log能够查看以往的提交记录;右键文件->TSVN->ShowLog能够查看与这个文件相关的提交记录

之四:恢复到曾经的版本号

SVN中的每一个修订版的不论什么文件都能够被获取到,所以仅仅要是提交过的文件,不用操心其改动的问题,即使改错了,也能够恢复到以往的随意一个版本号

详细操作是右键文件(或空白处——针对当前目录)->TSVN->Update to revision

之五:编辑冲突

如今来演示一下冲突问题:

你把test.txt的asdf所有换成别的文字

但不要提交

我也来改动相同的地方,然后提交后,你再尝试提交

【以上是大哥教我的时候的聊天记录,能够选择的做法是:在两个目录下check out同一个项目仓库,然后在两个目录下同一时候改动,能够有相同的效果】

SVN会提示出错,然后阻止你的提交

你这时候右键->SVN Update

SVN会将server上的版本号,以及你自己的版本号都分别放一个文件,选择test.txt右键->TSVN->Edit conflict

是一个典型的diff程序,你能够在左右两側分别比較

"Mine"和"Theirs"的版本号的差别,然后右键冲突的地方,选择要哪个地方的版本号

最后保存后,再度提交成为一个新的修订版【依据小子的实践,直接点击 mark as resolved就包含:save 和 commit,所以慎用此键】

之中的一个:提交的原则

关于提交,有一些基本原则,提交上去的代码

1. 不影响到其他开发人员开发的部分的功能

2. 能够执行,有程序bug没有关系,可是不要有错误(语法错误之类的)

在上面这个原则上,尽可能的多提交(当然也不用写两三行就提交一次,这个度要把握好),方便团队中的成员都拥有最新的版本号

之二:公布终于的版本号

终于公布的版本号(术语叫生产环境版本号),里面不须要.svn的数据,你仅仅须要在项目目录里面,右键,然后TSVN->Export导出,或者右键拖拽你的项目目录,有Export here的选项

SVN有用教程的更多相关文章

  1. [转载]SVN使用教程

    SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Subversion是什么? ...

  2. SVN使用教程总结[转]

    SVN使用教程总结   SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Sub ...

  3. SVN备份教程(三)

    上次的博文SVN备份教程(二)中,我们讲解了一下SVN定时备份的相关内容,同时我们又提出了一种新的SVN备份方案--自动备份. 1.简介 所谓自动备份,它实现的思路非常简单,就是利用SVN自带的hoo ...

  4. SVN备份教程(二)

    上次的博文中SVN备份教程(一)我们简单介绍了一下SVN备份是如何操作的,今天我们接着将上次的问题进行优化. 1.问题回顾 在讲之前,我们先来将上次的问题重申一下.之前的SVN备份存在的问题很简单,每 ...

  5. SVN简明教程

    SVN简明教程 Posted on 2010-09-07 17:34 幻海蓝梦 阅读(7196) 评论(0)  编辑  收藏 所属分类: 版本管理  http://www.emsym.com/blog ...

  6. Eclipse SVN 使用教程

    Eclipse SVN 使用教程 做好以上的准备后打开Eclipse编译器,点击编译器右上角的Open Perspective 打开SVN资源库界面,新建一个资源库 选择资源库的位置,这里我们就用刚才 ...

  7. SVN入门教程总结

    参考: SVN使用笔记 SVN入门必备教程 一看就懂 SVN使用教程总结 版本控制器:SVN教程 菜鸟教程之SVN教程 极客学院之SVN教程 SVN(SubVersion)简介: 为什么要使用SVN( ...

  8. 转: SVN使用教程总结(图文丰富,相当详细)

    转自:http://www.cnblogs.com/armyfai/p/3985660.html SVN使用教程总结   SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生 ...

  9. 安卓项目eclipse有用教程:设置应用名字和图标、屏幕、签名、真机调试、clean、logcat、json解析

    怎样在安卓项目中.设置游戏的应用名字和图标? 我们在Androidproject的res资源目录下.会看到3个drawable的目录和一个values目录.就是在这里改动即可.   关于改动应用程序名 ...

随机推荐

  1. linux根据该文件夹的读取权限和权限运行差异

    假设你linux下使用ls.细心的你会发现居然夹有权限运行.例如: drwxrwxr-x 11 cl cl 4096  9 25 14:22 ./ drwxr-xr-x 49 cl cl 4096 1 ...

  2. 《Qt on Android核心编程》夹

    china-pub在售前,售中环节退房,折扣低! 有朋友想看看<Qt on Android核心编程>的文件夹,So-- 文件夹     <Qt on Android核心编程>文 ...

  3. canvas绘制百分比圆环进度条

    开发项目,PM会跟踪项目进度:完成某个事情,也可以设置一个完成的进度. 这里用canvas绘制一个简单百分比圆环进度条. 看下效果: 1. 动画方式   2. 静默方式   // 贴上代码,仅供参考 ...

  4. 探索C/C++大数快(自然数)模板

    本文fcbruce个人原创整理.转载请注明出处http://blog.csdn.net/u012965890/article/details/40432511,谢谢. 我们知道在C/C++中int型可 ...

  5. java线程中的sleep和wait区别

                                                                            面试题:java线程中sleep和wait的区别以及其资 ...

  6. Ubuntu 14.04 Android 使用Maven一个 用例project

    在说明书前面描述SDK通过使用Ant发展. 本文试图在此基础上使用Maven发展. 在这里,我们需要使用maven-android-plugin. 在本文中,参考官方文件: https://code. ...

  7. Eclipse build launcher 3具体步骤

    1. 下载launcher 3源代码  (需要FQ) git clone https://android.googlesource.com/platform/packages/apps/Launche ...

  8. Vim常见操作汇总

    1.跳到文本的最后一行:按“G”,即“shift+g”2.跳到最后一行的最后一个字符 : 先重复1的操作即按“G”,之后按“$”键,即“shift+4”.3.跳到第一行的第一个字符:先按两次“g”,4 ...

  9. Monkey源代码分析番外篇WindowManager如何出的喷射事件的进程间的安全限制

    在分析monkey源代码时的一些背景知识不明确,例如看到monkey它是用windowmanager的injectKeyEvent的喷射事件时的方法.我发现自己陷入疙瘩,这种方法不仅能够在当前的应用程 ...

  10. 经验36--C#无名(大事,物...)

    有时候,方便代码,它会使用匿名的东西. 1.匿名事件 args.CookieGot += (s, e) =>                 {                     this ...