当前位置: 首页 > news >正文

SVN学习

SVN学习

以下总结是看了一个b站up主的视频总结出来的。

1. 简介

SVN是代码版本管理工具,它能记住每次的修改、查看所有修改记录、恢复到任何历史版本和恢复已经删除的文件。
SVN比起Git的好处就是使用简单,上手快;具备目录级权限控制,用户只能访问指定目录下的文件;且子目录就可以检出(Checkout),减少不必要的文件检出。

SVN的基础操作:检出(checkout)、新增(add)、提交(commit)和更新(update)。

2. 冲突

产生冲突的原因:当多个人修改了同个文件的同一行或者是修改无法合并的二进制文件。

避免冲突的方法:

  1. 经常更新(update)同步下他人的代码,保证自己的代码是最新版本,避免跟他人的代码差别越来越大;
  2. 二进制文件不要多个人同时操作。

3. 分支

什么情况下需要开分支?

  1. 隔离线上版本和开发版本;
  2. 大功能开发时,不想影响到其他人,自己独立开个分支去开发,需要时再合并回去。

SVN的目录结构:

  1. trunk(主干) 主要用来存放开发中的文件,平常开发都在主干上
  2. branches(分支) 当要开发另外一个版本时,就可以开一个分支出去
  3. tags(标签)

如果分支越来越多,则要更新的东西就会越来越多。所以可以把分支单独checkout一份出来。

在我看完视频后,我的理解是这样的,以下这个理解不对:
我的理解是主干用来存储最新版本,然后分支可以存储多个版本,分支里有上线的最新版本,每次修改分支里的最新版本时,需要同步到主干上。

正确的理解是这样的:
在SVN中,主干和分支的区别如下:

  1. 使用场景:主干(trunk)通常用于主开发目录,而分支(branches)则用于各种特定用途,例如版本发布维护、新特性开发或缺陷修复等。分支比较灵活一些,可以存放一些历史版本或者一些文档,这些不用更新到主干上。
  2. 稳定性:在开发过程中,持续集成通常验证的是分支上的稳定性和正确性,而主干在发布完成后往往没有进行集成验证,因此主干可能存在一定的风险。(每次测试,会将某个分支或几个分支集成去测试,测试没问题就会往主干上去合并,所以测试是可以保证分支是没问题的。但是主干是多个分支合并上去的且没有去把主干拿出来去验证,所以相对来说主干是可能存在一定的风险的)
  3. 更新速度:主干的更新速度通常比分支快,因为主干是主开发目录,包含了最新的开发成果。而分支的更新速度根据具体使用场景而定。
  4. 重要性:主干上的代码通常是核心功能或主要功能,因此其重要性较高。而分支上的代码则根据具体使用场景而定,如果是用于修复缺陷的分支,其重要性可能较低。

4. 总结

  1. SVN使用的注意事项:
    使用SVN管理代码之前最好的顺序是先更新,再修改再提交,这样做可以避免发生冲突。

  2. 遇到的问题:
    为什么“SVN在提交之前要先更新修改,为什么这样做就可以避免冲突”?
    经过反复研究后发现,当自己本地的代码没有先更新的情况下,这时自己修改完自己的代码,而SVN服务器上的代码恰好别人又已经更新了另外的版本时,这时要是点提交就会发生冲突,所以当我们要修改代码之前最后就是先更新一下自己本地的代码,确保本地的代码是最新版本,这时修改完再去提交就比较能避免冲突。

相关文章:

SVN学习

SVN学习 以下总结是看了一个b站up主的视频总结出来的。 1. 简介 SVN是代码版本管理工具,它能记住每次的修改、查看所有修改记录、恢复到任何历史版本和恢复已经删除的文件。 SVN比起Git的好处就是使用简单,上手快;具备目录级权限控制&…...

vim怎么使用,vim使用教程,vimtutor怎么切换中文 汉化

vim 使用 在安装了 vim 的 unix 系统下可以使用 vimtutor zh_cn 开启下面的教程 序言 欢 迎 阅 读 《 V I M 教 程 》 —— 版本 1.7 Vim 是一个具有很多命令的功能非常强大的编辑器。限于篇幅,在本教程当中就不详细介绍了。本教程的…...

[golang gin框架] 43.Gin商城项目-微服务实战之后台Rbac微服务之管理员的增删改查以及管理员和角色关联

上一节讲解了后台Rbac微服务角色增删改查微服务,这里讲解权限管理Rbac微服务管理员的增删改查微服务以及管理员和角色关联微服务功能 一.实现后台权限管理Rbac之管理员增删改查微服务服务端功能 1.创建Manager模型 要实现管理员的增删改查,就需要创建对应的模型,故在server/r…...

2023-07-31力扣每日一题

链接: 143. 重排链表 题意: 将链表L0 → L1 → … → Ln - 1 → Ln变成L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → … 解: 线性表法还是好写的 这边搞一下翻转法,快慢指针求翻转点(翻转后面一半然后双指针合并…...

接口自动化报告,生成本地服务并自动打开时失败

错误原因: 端口号被占用 首先可以在cmd中调出命令窗口然后执行命令netstat -ano就可以查看所有活动的链接,找到被占用的端口号 1、通过命令taskkill /f /t /im "进程名称" ,根据进程的名称杀掉所有的进程。或者taskkill /f /t /p…...

Git 的基本概念和使用方式

Git 是一种分布式版本控制系统,它能够记录文件内容的变化,并且允许用户在这些变化之间轻松地进行切换。 Git 的基本概念如下: 1. 仓库(Repository):Git 存放项目代码的地方。通常,一个仓库对应一…...

【JVM】(三) 深入理解JVM垃圾回收机制(GC)

文章目录 前言一、死亡对象的判断方法1.1 引用计数算法1.2 可达性分析算法 二、垃圾回收算法2.1 标记-清除算法2.2 复制算法2.3 标记-整理算法2.5 分代算法2.6 Minor GC 和 Major GC 前言 JVM 的垃圾回收机制(Garbage Collection)是 Java 中的重要特性之…...

Flink CEP(二) 运行源码解析

通过DemoApp学习一下&#xff0c;CEP的源码执行逻辑。为下一篇实现CEP动态Pattern奠定理论基础。 1. Pattern的定义 Pattern<Tuple3<String, Long, String>,?> pattern Pattern.<Tuple3<String, Long, String>>begin("begin").where(new…...

剑指Offer-学习计划(四)双指针(下)

剑指 Offer 57. 和为s的两个数字 剑指 Offer 58 - I. 翻转单词顺序 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 题目一&#xff1a;调整数组顺序使奇数位于偶数前面 输入一个整数数组&#xff0c;实现一个函数来调整该数组中数字的顺序&#xff0c;使得所有奇数在数组的…...

深度学习——常见注意力机制

1.SENet SENet属于通道注意力机制。2017年提出&#xff0c;是imageNet最后的冠军 SENet采用的方法是对于特征层赋予权值。 重点在于如何赋权 1.将输入信息的所有通道平均池化。 2.平均池化后进行两次全连接&#xff0c;第一次全连接链接的神经元较少&#xff0c;第二次全连…...

Python 进阶(七):高级文件操作(shutil 模块)

❤️ 博客主页&#xff1a;水滴技术 &#x1f338; 订阅专栏&#xff1a;Python 入门核心技术 &#x1f680; 支持水滴&#xff1a;点赞&#x1f44d; 收藏⭐ 留言&#x1f4ac; 文章目录 1. 简介2. 常用函数2.1 复制文件2.2 复制目录2.3 移动文件或目录2.4 删除文件或目录2.…...

保留网络:大型语言模型的Transformer继任者

原文信息 原文题目&#xff1a;《Retentive Network: A Successor to Transformer for Large Language Models》 原文引用&#xff1a;Sun Y, Dong L, Huang S, et al. Retentive Network: A Successor to Transformer for Large Language Models[J]. arXiv preprint arXiv:2…...

算法通关村第二关——反转链表青铜笔记

LeetCode 206.反转链表 建立虚拟结点辅助翻转 public ListNode reverseList(ListNode head) {ListNode ans new ListNode(-1);ListNode cur head;while(cur!null){ListNode curNext cur.next;cur.next ans.next;ans.next cur;cur curNext;}return ans.next; }不带虚拟头…...

【Linux】——线程安全

目录 关于线程进程的问题 可重入与线程安全 常见的线程安全的情况 常见的不可重入的情况 常见的可重入的情况 可重入与线程安全区别 可重入与线程安全联系 Linux线程互斥 进程线程间的互斥相关概念 互斥量mutex 互斥量mutex常用接口 互斥量改造抢票系统 互斥量的原…...

[React]生命周期

前言 学习React&#xff0c;生命周期很重要&#xff0c;我们了解完生命周期的各个组件&#xff0c;对写高性能组件会有很大的帮助. Ract生命周期 React 生命周期分为三种状态 1. 初始化 2.更新 3.销毁 初始化 1、getDefaultProps() 设置默认的props&#xff0c;也可以用duf…...

【2023】Redis实现消息队列的方式汇总以及代码实现

Redis实现消息队列的方式汇总以及代码实现 前言开始前准备1、添加依赖2、添加配置的Bean 具体实现一、从最简单的开始&#xff1a;List 队列代码实现 二、发布订阅模式&#xff1a;Pub/Sub1、使用RedisMessageListenerContainer实现订阅2、还可以使用redisTemplate实现订阅 三、…...

ARM裸机-10

1、X210开发板和光盘资料 1.1、配置信息 CPU&#xff1a;三星S5PV210 内存&#xff1a;512M DDR2 SDRAM Flash&#xff1a;4GB iBand LCD&#xff1a;7寸&#xff0c;分辨率800x480 触摸屏&#xff1a;电容触摸屏 2、X210开发板硬件手册 3、X210开发板刷系统 3.1、什么是刷…...

「C/C++」C/C++指针详解

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「C/C」C/C程序设计&#x1f4da;全部专栏「UG/NX」NX二次开发「UG/NX」BlockUI集合「VS」Visual Studio「QT」QT5程序设计「C/C」C/C程序设计「Win」Windows程序设计「算法」数据结构与算法「File」数据文件格式 目录 一、术语…...

提高电脑寿命的维护技巧与方法分享

在维护电脑运行方面&#xff0c;我有一些自己觉得非常有用的技巧和方法。下面我将分享一些我常用的维护技巧&#xff0c;并解释为什么我会选择这样做以及这样做的好处。 首先&#xff0c;我经常清理我的电脑内部的灰尘。电脑内部的灰尘会影响散热效果&#xff0c;导致电脑发热…...

React常见面试题

React常见面试题 一、React中的样式管理有哪些方法 内联样式&#xff1a;对象&#xff0c;作用于当前组件普通样式表&#xff1a; 作用于全局&#xff0c;文件名是&#xff1a;xxx.scssCSS模块&#xff1a;类似Vue的scoped&#xff0c; 文件名需是&#xff1a;xxx.module.scs…...

2024年Java开发者必看:这些过时技术可战略性放弃

1. 项目概述&#xff1a;重新审视Java学习的“必选项”最近在技术社区看到一个挺有意思的讨论&#xff0c;标题是“可以不必再学习的Java知识&#xff1f;”。这话题一出&#xff0c;立刻引起了我们这些老Java开发者的共鸣。从业十几年&#xff0c;从Java 5一路跟到现在的Java …...

EMD vs NEMD:分子动力学算热导率,新手到底该选哪个?

EMD与NEMD方法实战指南&#xff1a;如何为你的热导率计算选择最佳方案 在纳米材料和新型功能材料的研究中&#xff0c;热导率的精确计算是理解材料热输运性能的关键。面对平衡态分子动力学(EMD)和非平衡态分子动力学(NEMD)两种主流方法&#xff0c;许多研究者常常陷入选择困境。…...

Python爬虫遇到InsecureRequestWarning?别慌,这3种方法帮你搞定urllib3的SSL证书警告

Python爬虫遇到InsecureRequestWarning&#xff1f;3种专业级解决方案与安全实践 当你兴致勃勃地运行新写的Python爬虫脚本时&#xff0c;控制台突然跳出一堆黄字警告&#xff1a;"InsecureRequestWarning: Unverified HTTPS request is being made..."。这场景就像…...

STM32MP25x嵌入式Linux平台:集成XFCE、VNC、TSN的工业边缘计算解决方案

1. 项目概述&#xff1a;一个面向工业边缘的“瑞士军刀”级嵌入式平台最近&#xff0c;我们团队基于STM32MP25x系列核心板&#xff0c;成功构建并发布了一套完整的Debian系统镜像。这个项目的目标非常明确&#xff1a;打造一个开箱即用、功能全面、且能无缝覆盖从传统工业控制到…...

Agentic RAG的实现方式?

文档智能体开发正迎来“低门槛时代”。基于PaddleOCR与LangChain社区的集成合作&#xff0c;文心飞桨开发者进一步搭建了可视化管理工具ClawMaster——让开发者无需从零部署模型或编写复杂调用逻辑&#xff0c;10分钟即可跑通文档智能体工作流。与此同时&#xff0c;X-AnyLabel…...

CSP认证202305-1题保姆级攻略:用C++的map轻松搞定国际象棋局面去重

CSP认证202305-1题深度解析&#xff1a;从字符串处理到STL高效去重 国际象棋对局中的局面重复判定是一个经典的字符串处理问题&#xff0c;也是CSP认证考试中常见的题型。这道题看似简单&#xff0c;却蕴含了算法选择与数据结构应用的核心思想。本文将带您从题目分析、解法对比…...

电脑突然‘哑巴’了?保姆级排查指南:从服务、驱动到系统修复,一步步搞定Win10音频问题

电脑突然‘哑巴’了&#xff1f;保姆级排查指南&#xff1a;从服务、驱动到系统修复&#xff0c;一步步搞定Win10音频问题 右下角的小喇叭突然打上红叉&#xff0c;视频会议开到一半突然失声&#xff0c;游戏打到关键处却没了音效——这些场景恐怕每个Windows 10用户都遭遇过。…...

保姆级教程:Windows下VectorCAST License服务配置与常见启动失败排查

Windows平台VectorCAST License服务配置全指南与深度排错手册 引言 在嵌入式软件测试领域&#xff0c;VectorCAST作为行业领先的自动化测试工具链&#xff0c;其License服务的正确配置是保证团队高效协作的基础。然而&#xff0c;许多工程师在初次部署时&#xff0c;常因Window…...

智能视觉瞄准系统:基于YOLOv8的高效游戏辅助解决方案

智能视觉瞄准系统&#xff1a;基于YOLOv8的高效游戏辅助解决方案 【免费下载链接】RookieAI_yolov8 基于yolov8实现的AI自瞄项目 AI self-aiming project based on yolov8 项目地址: https://gitcode.com/gh_mirrors/ro/RookieAI_yolov8 RookieAI_yolov8是一个基于先进视…...

Intel 14代酷睿接口更迭:技术推演与用户决策指南

1. 项目概述&#xff1a;一次关于“接口更迭”的深度技术推演最近&#xff0c;关于下一代酷睿处理器的传闻又开始在圈内流传&#xff0c;一个核心的焦点再次被推上风口浪尖&#xff1a;Intel 14代酷睿&#xff08;Raptor Lake Refresh&#xff09;可能又要更换CPU插槽接口了。这…...