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

系统架构设计专业技能 ·操作系统

现在的一切都是为将来的梦想编织翅膀,让梦想在现实中展翅高飞。
Now everything is for the future of dream weaving wings, let the dream fly in reality.

点击进入系列文章目录

系统架构设计高级技能 · 操作系统

  • 一、操作系统概述
  • 二、进程管理
    • 2.1 进程概念
    • 2.2 进程状态
    • 2.3 进程的同步与互斥
    • 2.4 PV操作
    • 2.5 前趋图
    • 2.5 死锁
    • 2.6 银行家算法
  • 三、 存储管理
    • 3.1 逻辑地址与物理地址
    • 3.2 类型
    • 3.3 分区存储(连续空间)
    • 3.4 页式存储/分页存储(非连续空间)
    • 3.5 段式存储/分段存储(非连续空间)
    • 3.6 段页式存储管理(非连续空间)
    • 3.7 快表
    • 3.8 虚拟存储管理
    • 3.9 页面置换算法
  • 四、文件管理
    • 4.1 索引文件结构
    • 4.2 位示图
    • 4.3 树形目录结构
  • 五、设备管理
    • 5.1 数据传输控制方式
    • 5.2 I/O管理软件
  • 六、SPOOLing技术
  • 七、微内核

在这里插入图片描述

一、操作系统概述

操作系统的类型:批处理,分时,实时,网络操作系统和分布式操作系统。

操作系统具有的五大功能:处理器管理,存储管理,设备管理,文件管理和作业管理。不管任何类型的操作系统都有这样的分配。

现代的操作系统大多拥有两种工作状态:核心态和用户态。我们一般的应用程序工作在用户态,而内核模块和最基本的操作系统核心工作在核心态。

操作系统的结构可以分为无序结构,层次结构,面向对象结构,对称多处理结构和微内核结构。

在这里插入图片描述

二、进程管理

2.1 进程概念

进程是程序在一个数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。它由程序块、进程控制块(PCB)和数据块三部分组成。

PCB,PCB是进程存在的唯一标志,是进程的一个组成部分,是一种记录型数据结构。内容包含进程标识符、状态、位置信息、控制信息、队列指针(链接同一状态的进程)、优先级、现场保护区等。

在这里插入图片描述

进程与程序

进程与程序的区别:进程是程序的一次执行过程,没有程序就没有进程。

程序是一个静态的概念,而进程是一个动态的概念,它由创建而产生,完成任务后因撤销而消亡;进程是系统进行资源分配和调度的独立单位,而程序不是。

进程与线程

进程的2个基本属性:可拥有资源的独立单位,可独立调度和分配资源的基本单位。
一般情况下,一个进程会包含多个线程。

2.2 进程状态

三态图 :就绪,运行,阻塞三种状态。就绪的时候等待时间片从而运行,而阻塞是说明进程没有被喂饱资源,有了资源就到就绪态

五态图 :运行状态,活跃就绪状态,静止就绪状态,活跃阻塞状态和静止阻塞状态。除了运行态以外,阻塞态分为了静止阻塞和活跃阻塞,而就绪态也被分为了静止就绪和活跃就绪,这样就一共有了五个状态。
在这里插入图片描述
某计算机系统中的进程管理采用三态模型,如下组织方式采用索引方式,有2个运行进程,3个就绪进程,4个阻塞进程。
在这里插入图片描述

2.3 进程的同步与互斥

如何区分同步与互斥?

互斥,千军万马过独木桥,同类资源的竞争关系

同步,速度有差异,在一定情况停下等待,进程之间的协作关系

互斥,主要讲的是同类资源的竞争关系

一个进程在执行过程中,可能要停下来等等其他的进程,这就是同步(会有类似选择题)

多个进程共享一台打印机,典型互斥

消费者消费商品后生产者生产商品才可以投入市场,属于同步关系
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

2.4 PV操作

P是荷兰语的Passeren,V是荷兰语的Verhoogo。

PV操作是实现进程同步与互斥的常用方法。

P操作表示申请一个资源,负责获得资源并阻塞,V操作表示释放一个资源。

P操作和V操作是低级通信原语,在执行期间不可分割。

PV操作由P操作原语和V操作原语组成(原语是不可中断的过程)。

PV操作的意义:我们用信号量及PV操作来实现进程的同步和互斥。

信号量:是一种特殊的变量(全局的),习惯用大写S表示。

大部分情况下(没有事先说明),信号量S的初始值会被认为是1,1代表初始情况下有资源进行分配调用。

对信号量进行操作,具体定义如下:

P操作(请求分配一个资源):

将信号量S的值减1,即 S = S - 1
如果S >= 0,则该进程继续执行,否则该进程进入等待状态

V操作(释放一个资源):

将信号量S的值加1,即S = S + 1
如果S > 0,该进程继续执行,否则表示在等待队列中有某些进程正在等待该资源,需要唤醒等待
在这里插入图片描述

2.5 前趋图

前趋图是一个有向无循环图,由节点和有向边组成,节点代表各程序段的操作,而节点间的有向边表示两个程序段操作之间存在的前趋关系。用这种图可以描述多个程序或进程之间的执行顺序关系。

前趋图标记规则:从小到大,节点流出的都是V操作,流入的都是P操作,箭线代表一个信号量S。
在这里插入图片描述

2.5 死锁

进程管理是操作系统的核心,但如果设计不当,就会出现死锁的问题。如果一个进程在等待一件不可能发生的事,则进程就死锁了。而如果一个或多个进程产生死锁,就会造成系统死锁。

如何预防死锁:顺序资源分配(有序资源分配法),银行家算法。
在这里插入图片描述
死锁资源数计算

死锁计算公式:

​ 有m个共享资源,n个进程,每个进程所需的最大资源数为w, 那么仅是m > n * (w - 1)时,才会不死锁。

​ 也就是m至少 = n * (w - 1) + 1

典型例:系统有3个进程A、B、C,这3个进程都需要5个系统资源。如果系统至少有多少个资源,则不可能发生死锁?

按照死锁计算公式,3 * (5 - 1) = 12,系统至少需要12 + 1 = 13个资源。

2.6 银行家算法

银行家算法分配资源的原则:

(1)当一个进程对资源的最大需求量不超过系统中的资源数时,可以接纳该进程
(2)进程可以分期请求资源,但请求的总数不能超过最大需求量
(3)当系统现有的资源不能满足进程尚需资源数时,对进程的请求可以推迟分配,但总能使进程在有限的时间里得到资源。

三、 存储管理

3.1 逻辑地址与物理地址

逻辑地址 相对地址,CPU所生成的地址,逻辑地址是内部和编程使用的、并地址不唯一
物理地址 绝对地址,加载到内存地址寄存器中的地址,内存单元的真正地址
地址重定位,将程序中的虚拟地址(逻辑地址)变换成内存的真实地址(物理地址)的过程

3.2 类型

存储管理的主要目的是解决多个用户使用主存的问题,其存储管理方案主要包括分区存储管理、分页存储管理、分段存储管理、段页式存储管理以及虚拟存储管理。

分区存储管理:

分页存储管理:基本分页
分段存储管理:基本分段
段页式存储管理:基本段页式
虚拟存储管理:请求分页,请求分段,请求段页式,对应基本分页、分段、段页式

3.3 分区存储(连续空间)

分区存储管理,把主存的用户区划分成若干个区域,每个区域分配给一个用户作业使用,并限定它们只能在自己的区域中运行。

3.4 页式存储/分页存储(非连续空间)

页式存储 == 分页存储

将一个进程(程序)的地址空间划分成若干个大小相等的区域,称为页。

相应地,将主存(内存)空间划分成与页相同大小的若干个物理块,称为块或页框。

在为进程分配主存时,将进程中若干页分别装入多个不相邻接的块中。

优点:利用率高,碎片小,分配及管理简单。

缺点:增加了系统开销;可能产生抖动现象。
在这里插入图片描述
在这里插入图片描述

逻辑地址 = 页号 + 页内地址,物理地址 = 页帧号 + 页内地址

页式存储(细节问题):将程序与内存均划分为同样大小的块,以页为单位将程序调入内存
计算步骤 :
1、 逻辑地址拆分为:页号 + 页内地址
2、 页号 = 逻辑地址/页大小 页内地址 = 逻辑地址%页大小
3、 使用页表进行页号和物理块号对应映射
4、 物理地址 = 物理块号*页大小 + 页内地址

页大小/块大小的基本单位是B字节,注意单位转换
二进制、十进制和十六进制的区别,注意简便算法

页式存储主要考察,逻辑地址转换物理地址,注意各个进制的简便算法

3.5 段式存储/分段存储(非连续空间)

段式存储 == 分段存储

分段式存储管理系统中,为每个段分配一个连续的分区,而进程中的各个段可以离散地分配到主存的不同分区中。

在系统中为每个进程建立一张段映射表,简称为“段表”。每个段在表中占有一个表项,在其中记录了该段在主存中的起始地址(又称为“基址”)和段的长度。进程在执行时,通过査段表来找到每个段所对应的主存区。

段式存储:按用户作业中的自然段来划分逻辑空间,然后调入内存,段的长度可以不一样。

优点:多道程序共享内存,各段程序修改互不影响。

缺点:内存利用率低,内存碎片浪费大。
在这里插入图片描述
段式存储主要考察,主要判断逻辑地址是否合法(段号 + 偏移量),偏移量不能超过段长

“逻辑地址”到“物理地址”转换时会出现“地址越界”

3.6 段页式存储管理(非连续空间)

段页式系统的基本原理是先将整个主存划分成大小相等的存储块(页框),将用户程序按程序的逻辑关系分为若干个段,并为每个段赋予一个段名,再将每个段划分成若干页,以页框为单位离散分配。在段页式系统中,其地址结构由段号、段内页号和页内地址三部分组成。

段页式存储:段式与页式的综合体。先分段,再分页。1个程序有若干个段,每个段中可以有若干页,每个页的大小相同,但每个段的大小不同。

优点:空间浪费小、存储共享容易、存储保护容易、能动态连接。

缺点:由于管理软件的增加,复杂性和开销也随之增加,需要的硬件以及占用的内容也有所增加,使得执行速度大大下降。
在这里插入图片描述

3.7 快表

快表是一块小容量的相联存储器(Associative Memory),由高速缓存器组成,速度快,并且可以从硬件上保证按内容并行查找,一般用来存放当前访问最频繁的少数活动页面的页号。

快表:将页表存于Cache上;慢表:将页表存于内存上。

3.8 虚拟存储管理

在前面介绍的存储管理方案中,必须为每个作业分配足够的空间,以便装入全部信息。当主存空间不能满足作业要求时,作业无法装入主存执行。如果一个作业只部分装入主存便可开始启动运行.其余部分暂时留在磁盘上,在需要时再装入主存,这样可以有效地利用主存空间。从用户角度看,该系统所具有的主存容量将比实际主存容量大得多,人们把这样的存储器称为虚拟存储器。

3.9 页面置换算法

  • 最优置换算法OPT
  • 随机淘汰算法RAND
  • 先进先出算法FIFO, 可能“抖动”
  • 最近最久未使用算法LRU,不会“抖动” 利用理论依据“局部性原理”,淘汰最后被访问时间最久的元素
  • 最不经常使用页置换LFU,淘汰最近访问频率最小的元素
  • 时钟页面替换算法, 轮转算法,最近没有使用页面置换算法NUR

四、文件管理

4.1 索引文件结构

文件在逻辑上一定是连续的,在物理上可以是分散的。

文件的逻辑结构,方便用户使用;文件的物理结构,在物理设备的存放方式。

此部分经常考察逻辑号与物理号的计算转换,采取的具体什么类型索引,计算文件长度等等

直接索引范围 :索引块数量 * 索引块大小

一级间接索引范围 :(磁盘数据块(物理盘块)大小 / 地址项大小)* 索引块大小

二级间接索引范围 :(磁盘数据块(物理盘块)大小 / 地址项大小)的2次方 * 索引块大小

三级间接索引范围 :(磁盘数据块(物理盘块)大小 / 地址项大小)的3次方 * 索引块大小

在这里插入图片描述

在这里插入图片描述

4.2 位示图

位示图法 。该方法是在外存上建立一张位示图(Bitmap),记录文件存储器的使用情况。每一位仅对应文件存储器上的一个物理块,取值0和1分别表示空闲和占用。
在这里插入图片描述

位示图是利用二进制的一位来表示磁盘中的一个盘块的使用情况。当其值为“0”时,表示对应的盘块空闲;“1”时,表示已经分配。有的系统把"0"作为盘块已分配的标记,把“1”作为空闲标志。(它们的本质上是相同的,都是用一位的两种状态标志空闲和已分配两种情况。)磁盘上的所有盘块都有一个二进制位与之对应,这样,由所有盘块所对应的位构成一个集合,称为位示图。位示图是一种非常常用的结构,在索引,数据压缩等方面有广泛应用。

4.3 树形目录结构

在这里插入图片描述

五、设备管理

5.1 数据传输控制方式

设备输入/输出(I/O)管理的方式:

从上往下CPU的工作量越来越少,效率从上往下越来越高。

分区存储管理

  • 程序控制方式【CPU与I/O的串行工作 】: 分为无条件传送和程序查询方式两种。方法简单,硬件开销小,但I/O能力不高,严重影响CPU的利用率。程序查询方式,CPU必须不停的测试I/O设备的状态端口
  • 程序中断方式【CPU与I/O的并行工作 】:
    与程序控制方式相比,中断方式因为CPU无需等待而提高了传输请求的响应速度。CPU通过调用中断控制设备获得设备状态,设备通过中断通知CPU状态改变、获得数据等。中断结束后CPU会继续执行之前的程序__ 。
  • DMA(直接内存存取)【CPU与I/O的并行工作 】:
    为了在主存和外设之间实现高速,批量数据交换而设置的。DMA方式比程序控制方式与中断方式都高效。DMA控制器与内存直接进行批量数据交换,CPU只控制开始和结束,传输过程无需CPU干预。
    DMA硬件直接完成,无需CPU做任何干涉,适合快速I/O设备,且在CPU一个总线结束后相应DMA
  • 通道方式【CPU与I/O的并行工作 】:
    主机中有专门的通道处理器,CPU干预更少,有对应的通道程序和通道状态字保存在内存中,CPU向通道处理器发出启动指令即可不管,通道处理器执行通道程序控制设备传输完所有数据之后发起一个中断交给CPU处理,设备挂接在通道上。
  • 输入输出处理机(IOP)【CPU与I/O的并行工作 】:
    一个独立的系统,有自己的内存、指令熊、中断,专用于大型高效系统的输入输出设备控制,利用共享存储器等与主机交换信息。输入输出处理机中可能有多个通道连接设备。

5.2 I/O管理软件

在这里插入图片描述

  • 硬件,完成具体的I/O操作。
  • 中断处理程序:,I/O完成后唤醒设备驱动程序
  • 设备驱动程序,设置寄存器,检查设备状态
  • 设备无关I/O层,设备名解析、阻塞进程、分配缓冲区
  • 用户级I/O层(用户进程),发出I/O调用。

六、SPOOLing技术

SPOOLing是Simultaneous Peripheral Operation On-Line (即外部设备联机并行操作)的缩写,它是关于慢速字符设备如何与计算机主机交换信息的一种技术,通常称为"假脱机技术"。

SPOOLing技术(虚拟输入输出设备常用到的技术)先放入到磁盘缓冲区,再放入到设备区,它是在磁盘上开辟响应的区域,所以缓冲区是外存。

SPOOLing技术将一台独享打印机改造为可供多个用户共享的打印机。

SPOOLing技术特点:

(1)输入井和输出井,在磁盘上开辟出来的两个存储区域,用于存放I/O设备输入的数据和用户程序向设备输出的数据
(2)输入缓存区和输出缓冲区,在内存中开辟的两个缓冲区。输入缓冲区用户暂存输入设备送来的数据,再送入输入井;输出缓冲区暂存从输出井送来的数据,再传送到输出设备
(3)输入进程和输出京城,负责传输输入输出的数据
(4)提高了I/O速度,通过对输入井和输出井的操作,缓和了主机和外设速度不匹配的矛盾
(5)设备没有直接和用户进程关联
(6)实现虚拟设备,多个进程同时使用一个逻辑设备,每个进程都认为自己独占了设备

七、微内核

  • 微内核就是对操作系统进行瘦身,只保留最为基本的功能。普通的操作系统内核包括了进程,存储,设备,文件,任务管理五个部分,而在 微内核操作系统 中,已对其 进行了裁剪,文件系统,通信,外设管理都放到操作系统之外 去处理了。
  • 现代操作系统大多拥有两种工作状态,分别是 核心态用户态。一般应用程序工作在用户态,而内核模块和最基本的操作系统核心工作在核心态。因为在微内核中,核心态功能少了,很多原本属于操作系统的操作放到了用户态去实施了。
  • 微内核系统的安全性,可靠性得到了提升。微内核操作系统在分布式中有着广泛的应用,它也成为了微内核操作系统的最大优势。
  • 当然微内核操作系统中,一个任务需要不断的在用户态和核心态直接切换来完成,频繁地切换效率自然不会很高。

将传统的操作系统代码放置到更高层,从操作系统中去掉尽可能多的东西,而只留下最小的核心,称之为微内核(C/S结构)。
在这里插入图片描述

实质优点缺点
单体内核将图形、设备驱动及文件系统等功能全部在内核中实现,运行在内核状态和同一地址空间减少进程间通信和状态切换的系统开销,获得较高的运行效率内核庞大,占用资源较多且不易剪裁。系统的稳定性和安全性不好
微内核只实现基本功能,将图形系统、文件系统、设备驱动及通信功能放在内核之外内核精练,便于剪裁和移植。系统服务程序运行在用户地址空间,系统的可靠性、稳定性和安全性较高,可用于分布式系统用户状态和内核状态需要频繁切换,从而导致系统 效率不如单体内核

点击进入系列文章目录

相关文章:

系统架构设计专业技能 ·操作系统

现在的一切都是为将来的梦想编织翅膀,让梦想在现实中展翅高飞。 Now everything is for the future of dream weaving wings, let the dream fly in reality. 点击进入系列文章目录 系统架构设计高级技能 操作系统 一、操作系统概述二、进程管理2.1 进程概念2.2 进…...

CSP 202209-1 如此编码

答题 题目就是字多 #include<iostream>using namespace std;int main() {int n,m;cin>>n>>m;int a[n],c[n1];c[0]1;for(int i0;i<n;i){cin>>a[i];c[i1]c[i]*a[i];}for(int i0;i<n;i){cout<<(m%c[i1]-m%c[i])/c[i]<< ;} }...

windows安装向量数据库milvus

本文介绍windows下安装milvus的方法。 一.Docker安装 1.1docker下载 首先到Docker官网上下载docker:Docker中文网 官网 1.2.安装前前期准备 先使用管理员权限打开windows powershell 然后在powershell里面输入下面那命令&#xff0c;启用“适用于 Linux 的 Windows 子系统”…...

Qt中,QScript对JavaScript的内置接口支持情况

支持 JSON.parse()/stringify() Object.keys() 不支持 console.info()/debug()/warn()/error() window setTimeout() clearTimeout() setInterval() clearInterval() 后续添加更多接口支持情况~...

C语言基础-typedef的用法

文章目录 前言基础用法高阶用法typedef作用于数组typedef作用于函数指针 总结 前言 熟悉C语言的同学&#xff0c;应该都见过typedef&#xff0c;但可能对typedef的用法并不是真的了解。本文介绍几种typedef的用法&#xff0c;相信会有所帮助 基础用法 一般typedef用来声明一个…...

Linux中安装MySQL5.7.42

1. 首先&#xff0c;下载mysql5.7.42的安装包&#xff08;下方是下载地址&#xff09;&#xff0c;选择红色框框的下载&#xff08;注意的是&#xff0c;这个链接只提供5.7的版本下载&#xff0c;可能还会更新&#xff0c;不一定打开就是5.7.42的版本&#xff0c;后续可能会有4…...

网络基础--1.网络纵横

网络的发展历程 计算机由原来的只能单一处理信息&#xff08;单用户批处理&#xff09;逐步发展为多用户批处理&#xff0c;可以实现一台计算机连接多个终端同时使用一台计算机&#xff08;分时系统&#xff09;&#xff0c;但是多个终端之间不能相互通信&#xff0c;再发展成为…...

Django TypeError: Abstract models cannot be instantiated.错误解决方案

问题 [2023-09-05 10:23:41][dvadmin.utils.exception.CustomExceptionHandler():64] [ERROR] Traceback (most recent call last): File “D:\InstallSpace\Anaconda3\envs\py39\lib\site-packages\rest_framework\views.py”, line 506, in dispatch response handler(requ…...

vscode使用delve调试golang程序

环境配置 delve仓库&#xff0c;含有教程&#xff1a;https://github.com/go-delve/delve golang的debugging教程&#xff1a;https://github.com/golang/vscode-go/wiki/debugging > go version go version go1.20 windows/amd64> go install github.com/go-delve/de…...

如何从任何苹果、Windows或安卓设备访问iCloud照片

本文介绍了如何在各种设备上访问iCloud照片库,包括iPhone和iPad、Mac、Windows PC和Android设备。说明适用于iOS 13及以上版本、iPadOS 13及以上、macOS Big Sur(10.16)和Catalina(10.15)、Windows 10或11以及Android 10。 从iPhone、iPod Touch和iPad访问iCloud照片 照…...

关于“找不到mfc140u.dll,无法继续执行代码”问题的分析处理方法

我想和大家分享一个在编程过程中经常会遇到的问题——找不到mfc140u.dll,无法继续执行代码。找不到 mfc140u.dll&#xff0c;这个问题可能会让我们感到困扰。mfc140u.dll 是 Microsoft Foundation Classes&#xff08;MFC&#xff09;库的一部分&#xff0c;它是一个 Windows 系…...

用 TripletLoss 优化bert ranking

下面是 用 TripletLoss 优化bert ranking 的demo import torch from torch.utils.data import DataLoader, Dataset from transformers import BertModel, BertTokenizer from sklearn.metrics.pairwise import pairwise_distancesclass TripletRankingDataset(Dataset):def __…...

Tomcat安装及使用

这里写目录标题 Tomcat一.java基础1.java历史2.java组成3.实现动态网页功能serveltjsp 4.jdkJDK 和 JRE 关系安装openjdk安装oracle官方JDK 二.tomcat基础功能1.Tomcat介绍2.安装tomcat二进制安装Tomcat 3.配置文件介绍及核心组件配置文件组件 4.状态页5.常见的配置详解6.tomca…...

法国新法案强迫 Firefox 等浏览器审查网站

导读Mozilla 基金会已发起了一份请愿书&#xff0c;旨在阻止法国政府强迫 Mozilla Firefox 等浏览器审查网站。 据悉&#xff0c;法国政府正在制定一项旨在打击网络欺诈的 SREN 法案 (“Projet de loi Visant scuriser et reguler lespace numrique”)&#xff0c;包含大约 2…...

开源电商项目 Mall:构建高效电商系统的终极选择

文章目录 Mall 项目概览前台商城系统后台管理系统系统架构图业务架构图 模块介绍后台管理系统 mall-admin商品管理&#xff1a;功能结构图-商品订单管理&#xff1a;功能结构图-订单促销管理&#xff1a;功能结构图-促销内容管理&#xff1a;功能结构图-内容用户管理&#xff1…...

QT(9.1)对话框与事件处理

作业&#xff1a; 1. 完善登录框 点击登录按钮后&#xff0c;判断账号&#xff08;admin&#xff09;和密码&#xff08;123456&#xff09;是否一致&#xff0c;如果匹配失败&#xff0c;则弹出错误对话框&#xff0c;文本内容“账号密码不匹配&#xff0c;是否重新登录”&…...

C++项目实战——基于多设计模式下的同步异步日志系统-③-前置知识补充-设计模式

文章目录 专栏导读六大原则单例模式饿汉模式懒汉模式 工厂模式简单工厂模式工厂方法模式抽象工厂模式 建造者模式代理模式 专栏导读 &#x1f338;作者简介&#xff1a;花想云 &#xff0c;在读本科生一枚&#xff0c;C/C领域新星创作者&#xff0c;新星计划导师&#xff0c;阿…...

C++ 新旧版本两种读写锁

一、简介 读写锁&#xff08;Read-Write Lock&#xff09;是一种并发控制机制&#xff0c;用于多线程环境中实现对共享资源的高效读写操作。读写锁允许多个线程同时读取共享资源&#xff0c;但在有写操作时&#xff0c;需要互斥地独占对共享资源的访问&#xff0c;以确保数据的…...

ES6 字符串的repeat()方法

repeat() 方法返回一个新字符串&#xff0c;表示将原字符串重复n次 格式&#xff1a;str.repeat(n) 参数n&#xff1a;str需要重复多少次 参数n的取值&#xff1a; n是正整数&#xff1a; x.repeat(3) // 输出结果&#xff1a;"xxx" hello.repeat(2) // 输出结果…...

【车载以太网测试从入门到精通】系列文章目录汇总

【车载以太网测试从入门到精通】——物理层测试 【车载以太网测试从入门到精通】——数据链路层测试 【车载以太网测试从入门到精通】——网络层测试 【车载以太网测试从入门到精通】——传输层测试 【车载以太网测试从入门到精通】——以太网TCP/IP协议自动化测试&#xff08;…...

LLM推理优化技术综述:KVCache、PageAttention、FlashAttention、MQA、GQA

LLM推理优化技术综述&#xff1a;KVCache、PageAttention、FlashAttention、MQA、GQA 随着大模型被越来越多的应用到不同的领域&#xff0c;随之而来的问题是应用过程中的推理优化问题&#xff0c;针对LLM推理性能优化有一些新的方向&#xff0c;最近一直在学习和研究&#xf…...

go开发之个微机器人的二次开发

请求URL&#xff1a; http://域名/addRoomMemberFriend 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-Type&#xff1a;application/jsonAuthorization&#xff1a;login接口返回 参数&#xff1a; 参数名必选类型说明wId是String登录实例标识chatRoom…...

2023国赛数学建模B题思路代码 - 多波束测线问题

# 1 赛题 B 题 多波束测线问题 单波束测深是利用声波在水中的传播特性来测量水体深度的技术。声波在均匀介质中作匀 速直线传播&#xff0c; 在不同界面上产生反射&#xff0c; 利用这一原理&#xff0c;从测量船换能器垂直向海底发射声波信 号&#xff0c;并记录从声波发射到…...

SpringAOP面向切面编程

文章目录 一. AOP是什么&#xff1f;二. AOP相关概念三. SpringAOP的简单演示四. SpringAOP实现原理 一. AOP是什么&#xff1f; AOP&#xff08;Aspect Oriented Programming&#xff09;&#xff1a;面向切面编程&#xff0c;它是一种编程思想&#xff0c;是对某一类事情的集…...

A Guide to Java HashMap

原文链接: A Guide to Java HashMap → https://www.baeldung.com/java-hashmap 从Map里取值 # 原生方法 Map<String, Integer> map new HashMap<>();// map自身的方法 → 取不到返回null Integer age6 map.get("name"); // Integer时返回null可…...

LeetCode 449. Serialize and Deserialize BST【树,BFS,DFS,栈】困难

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…...

嵌入式IDE(1):IAR中ICF链接文件详解和实例分析

最近在使用NXP的提供的MCUXPresso IDE&#xff0c;除了Eclipse固有的优点外&#xff0c;我觉得它最大的优点就是在链接脚本的生成上&#xff0c;提供了非常直观的GUI配置界面。但这个IDE仅仅支持NXP相关的产品&#xff0c;而且调试的性能在某些情况下并不理想。而我们用得比较多…...

分布式版本控制工具——git

✅<1>主页&#xff1a;&#xff1a;我的代码爱吃辣 &#x1f4c3;<2>知识讲解&#xff1a;Linux——git ☂️<3>开发环境&#xff1a;Centos7 &#x1f4ac;<4>前言&#xff1a;git是一个开源的分布式版本控制系统&#xff0c;可以有效、高速地处理从很…...

C基础-数组

1.一维数组的创建和初始化 int main() {// int arr1[10];int n 0;scanf("%d",&n);//int count 10;int arr2[n]; //局部的变量&#xff0c;这些局部的变量或者数组是存放在栈区的&#xff0c;存放在栈区上的数组&#xff0c;如果不初始化的话&#xff0c;默认…...

springboot项目配置flyway菜鸟级别教程

1、Flyway的工作原理 Flyway在第一次执行时&#xff0c;会创建一个默认名为flyway_schema_history的历史记录表&#xff0c;这张表会用来跟踪或记录数据库的状态&#xff0c;然后每次项目启动时都会自动扫描在resources/db/migration下的文件的版本号并且通过查询flyway_schem…...