【操作系统】内存管理(四)—— 内存的分配与回收(2)

2023-11-01

【操作系统】内存管理(四)—— 内存的分配与回收(2)

前言:操作系统内存的分配分为连续分配管理方式和非连续分配管理方式,本章主要介绍非连续分配管理方式。

内存连续分配管理的介绍可见:
https://blog.csdn.net/weixin_43848614/article/details/126803818

一、非连续分配管理方式

连续分配:为用户进程分配的必须是一个连续的内存空间。
非连续分配:为用户进程分配的可以是一些分散的内存空间

  • 基本分页存储管理
  • 基本分段存储管理
  • 段页式存储管理

(一)、基本分页存储管理

1. 分页

内存空间分为一个个大小相等的分区(比如:每个4KB),每个分区就是一个“页框”(页框=页帧=内存块=物理块=物理页面)。每个页框有一个编号,即“页框号”(页框号=页帧号=内存块号=物理块号=物理页号),页框号从0开始。

进程的逻辑地址空间也分为与页框大小相等的一个个部分,每个部分称为一个“页”或“页面” 。每个页面也有一个编号,
即“页号”,页号也是从0开始。

注:进程的最后一个页面可能没有一个页框那么大。也就是
说,分页存储有可能产生内部碎片,因此页框不能太大,否则
可能产生过大的内部碎片造成浪费

页框=页帧=内存块=物理块=物理页面

在这里插入图片描述
地址结构包含两个部分:前一部分为页号,后一部分为页内偏移量 W。在上图所示的例子中,地址长度为 32 位,其中 0~11位 为 “页内偏移量”,或称 “页内地址”;12~31 位为 “ 页号 ”。
如果有 K 位表示“页内偏移量”,则说明该系统中一个页面的大小是 2 K 2^K 2K个内存单元;
如果有 M 位表示“页号”,则说明在该系统中,一个进程最多允许有 2 M 2^M 2M 个页面。

在这里插入图片描述

操作系统以页框为单位为各个进程分配内存空间。进程的每个页面分别放入一个页框中。也就是说,进程的页面与内存的页框有一一对应的关系。

各个页面不必连续存放,可以放到不相邻的各个页框中。

2. 重要的数据结构 —— 页表

为了能知道进程的每个页面在内存中存放的位置,操作系统要为每个进程建立一张页表。【注:页表通常存在PCB(进程控制块)中

在这里插入图片描述

1. 一个进程对应一张页表
2. 进程的每个页面对应一个页表项
3. 每个页表项由 “页号” 和 “块号” 组成
4. 页表记录进程页面和实际存放的内存块之间的映射关系
5. 每个页表项的长度是相同的,页号是“隐含”的。

Eg:假设某系统物理内存大小为 4GB,页面大小为 4KB,则
每个页表项至少应该为多少字节?
内存块大小=页面大小=4KB= 212 B
4GB 的内存总共会被分为 232 / 212 = 220个内存块
内存块号的范围应该是 0 ~ 220 -1
内存块号至少要用 20 bit 来表示
至少要用3B来表示块号(38=24bit)
由于页号是隐含的,因此每个页表项占3B,存储整个页表至少需要 3
(n+1)B

注意:页表记录的只是内存块号,而不是内存块的起始地址!
J 号内存块的起始地址 = J * 内存块大小

总结:页面大小刚好是 2 的整数幂有什么好处?
① 逻辑地址的拆分更加迅速——如果每个页面大小为 2KB,用二进制数表示逻辑地址,则末尾 K 位即为页内偏移量,其余部分就是页号。因此,如果让每个页面的大小为 2 的整数幂,计算机硬件就可以很方便地得出一个逻辑地址对应的页号和页内偏移量,而无需进行除法运算,从而提升了运行速度。

② 物理地址的计算更加迅速——根据逻辑地址得到页号,根据页号查询页表从而找到页面存放的内存块号,将二进制表示的内存块号和页内偏移量拼接起来,就可以得到最终的物理地址。

结论:如果页面大小刚好是2的整数幂,则只需把页表中记录的物理块号拼接上页内偏移量就能得到对应的物理地址

在这里插入图片描述

3. 基本分页式的基本地址变换机构(逻辑地址到物理地址的转换)

基本地址变换机构(用于实现逻辑地址到物理地址转换的一组硬件机构)的原理和流程。

通常会在系统中设置一个页表寄存器(PTR),存放页表在内存中的起始地址F页表长度M

进程未执行时,页表的始址 和 页表长度放在进程控制(PCB)中,当进程被调度时,操作系统内核会把它们放到页表寄存器中。

注意:页面大小是2的整数幂
设页面大小为L,逻辑地址A 到物理地址E 的变换过程如下:

  1. 计算页号P(P = A/L)和页内偏移量W(W=A%L)。
  2. 比较页号Р 和页表长度M,若 P>M,则产生越界中断,否则继续执行。
  3. 页表中页号Р 对应的页表项地址 = 页表始址F + 页号P x 页表项长度,取出该页表项内容b,即为物理块号。要注意区分页表长度和页表项长度。页表长度的值是指一共有多少页,页表项长度是指页地址占多大的存储空间。
  4. 计算 E= b * L+W,用得到的物理地址E 去访问内存。

在这里插入图片描述

例:若页面大小L 为 1K 字节,页号2对应的内存块号 b = 8,将逻辑地址 A=2500 转换为物理地址E。

等价描述:某系统按字节寻址,逻辑地址结构中,页内偏移量占10位,页号2对应的内存块号 b = 8, 将逻辑地址 A=2500
转换为物理地址E。

答案: ①计算页号、页内偏移量 页号P = A/L = 2500/1024 = 2; 页内偏移量 W = A%L = 2500%1024 =
452 ②根据题中条件可知,页号2没有越界,其存放的内存块号 b = 8 ③物理地址 E = b * L + W = 8 * 1024 +
425 = 8644

4. 页表项的大小

实际应用中,通常使一个页框恰好能够放入整数个页表项。

在这里插入图片描述
上述例题结论:理论上,页表项长度为 3B 即可表示内存块号的范围,但是,为了方便页表的查询,常常会让一个页表项占更多的字节,使得每个页面恰好可以装得下整数个页表项

在这里插入图片描述

5. 具有快表的地址变换机构

具有快表的地址变换机构是基本地址变换机构的改进版本

快表

快表,又称联想寄存器(TLB, translation lookaside buffer ),是一种访问速度比内存快很多的高速缓存(TLB不是内存!),用来存放最近访问的页表项的副本,可以加速地址变换的速度。与此对应,内存中的页表常称为慢表

在这里插入图片描述
引入快表后,地址的变换过程

① CPU给出逻辑地址,由某个硬件算得页号、页内偏移量,将页号与快表中的所有页号进行比较。

② 如果找到匹配的页号,说明要访问的页表项在快表中有副本,则直接从中取出该页对应的内存块号,再将内存块号与页内偏移量拼接形成物理地址,最后,访问该物理地址对应的内存单元。因此,若快表命中,则访问某个逻辑地址仅需一次访存即可。

③ 如果没有找到匹配的页号,则需要访问内存中的页表,找到对应页表项,得到页面存放的内存块号,再将内存块号与页内偏移量拼接形成物理地址,最后,访问该物理地址对应的内存单元。因此,若快表未命中,则访问某个逻辑地址需要两次访存(注意:在找到页表项后,应同时将其存入快表,以便后面可能的再次访问。但若快表已满,则必须按照一定的算法对旧的页表项进行替换

在这里插入图片描述

局部性原理

时间局部性:如果执行了程序中的某条指令,那么不久后这条指令很有可能再次执行;如果某个数据被访问过,不久之后该数据很可能再次被访问。(因为程序中存在大量的循环)

空间局部性:一旦程序访问了某个存储单元,在不久之后,其附近的存储单元也很有可能被访问。(因为很多数据在内存中都是连续存放的)
在这里插入图片描述

TLB 和 普通 Cache 的区别——TLB 中只有页表项的副本,而普通 Cache 中可能会有其他各种数据的副本。

6. 两级页表

在这里插入图片描述

单级页表存在的问题

某计算机系统按字节寻址,支持 32 位的逻辑地址,采用分页存储管理,页面大小为 4KB,页表项长度为 4B。

4KB = 2 12 2^{12} 212B,因此页内地址要用12位表示,剩余 20 位表示页号。因此,该系统中用户进程最多有 2 20 2^{20} 220 页。相应的,一个进程的页表中,最多会有 2 20 2^{20} 220 = 1M = 1,048,576 个页表项,所以一个页表最大需要 2 20 2^{20} 220 * 4B = 2 22 2^{22} 222 B,共需要 2 22 / 2 12 = 2 10 2^{22} / 2^{12} = 2^{10} 222/212=210个页框存储该页表。需要专门给进程分配 1024 个连续的页框来存放它的页表

根据局部性原理可知,很多时候,进程在一段时间内只需要访问某几个页面就可以正常运行了。因此没有必要让整个页表都常驻内存

页表再分页并离散存储,然后再建立一张页表记录页表各个部分的存放位置,称为页目录表,或称外层页表,或称顶层页表。

7. 两级页表的原理、地址结构

32位逻辑地址空间,页表项大小为4B,页面大小为 4KB,则页内地址占12位。每个页面可存放 4K/4 =1K = 2 10 2^{10} 210 = 1024 个页表项。

10位一级页号刚好可表示 0~1023,之前计算出页内偏移地址占用了 12 位,还剩下 10 位,恰好使得二级页表的大小在一页之内。

在这里插入图片描述

地址变换过程:
①按照地址结构将逻辑地址拆分成三部分;
②从PCB 中读出页目录表始址,再根据一级页号查页目录
表,找到下一级页表在内存中的存放位置;
③根据二级页号查二级页表,找到最终想访问的内存块号;
④结合页内偏移量得到物理地址。

在这里插入图片描述

两级页表的访存次数分析(假设没有快表机构)

第一次访存:访问内存中的页目录表
第二次访存:访问内存中的二级页表
第三次访存:访问目标内存单元

8. 多级页表

在这里插入图片描述
如果只分为两级页表,则一级页号占 18 位,也就是说页目录表中最多可能有 2 18 2^{18} 218 个页表项,显然,一个页面是放不下这么多页表项的。

9. 两级页表总结

在这里插入图片描述

(二)、基本分段存储管理

在这里插入图片描述
与“分页”最大的区别就是——离散分配时所分配地址空间的基本单位不同。

1. 分段

进程的地址空间:按照程序自身的逻辑关系划分为若干个段,每个段都有一个段名(在低级语言中,程序员使用段名来编程),每段从0开始编址

内存分配规则:以段为单位进行分配,每个段在内存中占据连续空间,但各段之间可以不相邻

分段系统的逻辑地址结构由段号(段名)和段内地址(段内偏移量)所组成。如:

在这里插入图片描述
段号的位数决定了每个进程最多可以分几个段
;段内地址位数决定了每个段的最大长度是多少

在上述例子中,若系统是按字节寻址的,则段号占16位,因此在该系统中,每个进程最多有 2 1 6 2^16 216 = 64K 个段。段内地址占 16位,因此每个段的最大长度是 2 1 6 2^16 216 = 64KB。

2. 段表

程序分多个段,各段离散地装入内存,为了保证程序能正常运行,就必须能从物理内存中找到各个逻辑段的存放位置。为此,需为每个进程建立一张段映射表,简称“段表”。

在这里插入图片描述

  1. 每个段对应一个段表项,其中记录了该段在内存中的起始位置(又称“基址”)段的长度
  2. 各个段表项的长度是相同的。例如:某系统按字节寻址,采用分段存储管理,逻辑地址结构为(段号16位, 段内地址16位),因此用16位即可表示最大段长。物理内存大小为4GB(可用32位表示整个物理内存地址空间)。因此,可以让每个段表项占 16+32 = 48位,即 6B。由于段表项长度相同,因此段号可以是隐含的,不占存储空间。若段表存放的起始地址为 M,则 K号段对应的段表项存放的地址为 M + K*6

3. 段式的地址变换

在这里插入图片描述

4. 分段、分页管理的对比

  1. 页是信息的物理单位。分页的主要目的是为了实现离散分配,提高内存利用率。分页仅仅是系统管理上的需要,完全是系统行为,分页对用户是不可见的
    段是信息的逻辑单位。分段的主要目的是更好地满足用户需求。一个段通常包含着一组属于一个逻辑模块的信息。分段对用户是可见的,用户编程时需要显式地给出段名。

  2. 页的大小固定且由系统决定。段的长度却不固定,决定于用户编写的程序。

  3. 分页的用户进程地址空间是一维的,程序员只需给出一个记忆符即可表示一个地址。分段的用户进程地址空间是二维的,程序员在标识一个地址时,既要给出段名,也要给出段内地址。

  4. 分段比分页更容易实现信息的共享和保护。不能被修改的代码称为纯代码或可重入代码(不属于临界资源),这样的代码是可以共享的。可修改的代码是不能共享的。

在这里插入图片描述

思考:访问一个逻辑地址需要几次访存?

解答:

  1. 分页(单级页表):第一次访存——查内存中的页表,第二次访存——访问目标内存单元。总共两次访存。

  2. 分段:第一次访存——查内存中的段表,第二次访存——访问目标内存单元。总共两次访存。

  3. 与分页系统类似,分段系统中也可以引入快表机构,将近期访问过的段表项放到快表中,这样可以少一次访问,加快地址变换速度。

5. 基本分段存储管理总结

在这里插入图片描述

(三)、段页式存储管理

在这里插入图片描述

1. 分页、分段的优缺点分析

在这里插入图片描述
分段管理中产生的外部碎片也可以用“紧凑”来解决,只是需要付出较大的时间代价。

2. 段页式管理方式(分段+分页=段页式管理)

将进程按逻辑模块分段,再将各段分页,再将内存空间分为大小相同的内存块/页框/页帧/物理块进程前将各页面分别装入各内存块中。

在这里插入图片描述

3. 段页式管理的逻辑地址结构

在这里插入图片描述

段号的位数决定了每个进程最多可以分几个段;页号位数决定了每个段最大有多少页;页内偏移量决定了页面大小、内存块大小是多少。

  • 每个段对应一个段表项,每个段表项由段号、页表长度、页表存放块号(页表起始地址)组成。每个段表项长度相等,段号是隐含的。
  • 每个页面对应一个页表项,每个页表项由页号、页面存放的内存块号组成。每个页表项长度相等,页号是隐含的。

在这里插入图片描述

注:在一个进程中,段表只有一个,而页表可能有多个。

“分段”对用户是可见的,程序员编程时需要显式地给出段号、段内地址。而将各段“分页”对用户是不可见的。系统会根据段内地址自动划分页号和页内偏移量。因此段页式管理的地址结构是二维的。

4. 段页式的地址变换

在这里插入图片描述

5. 段页式存储管理总结

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【操作系统】内存管理(四)—— 内存的分配与回收(2) 的相关文章

  • 计算机网路基础 - 一些基本概念与网络结构

    1 基本概念 计算机网络 通信技术 计算机技术 是两项技术紧密结合的产物 通信系统的基础模型 计算机网络 是指将地理位置不同 具有独立功能的多台计算机及其外部设备 通过通信线路连接 在网络操作系统 网络管理软件及网络通信协议的管理和协调下
  • Tomcat7安装及配置教程

    Apache Tomcat7 0安装及配置教程 Apache Tomcat7 0官方网站链接 http tomcat apache org apache tomcat 7 0 73 windows x64 先解压下载的压缩包 然后在bin目
  • 计算机领域中随处可见的抽象

    想要管理多种具体的东西 那么需要遵守每种东西的规范 如果想要提供一种通用模式来对这些具体的东西统一管理 需要使用一种古老的技术 抽象 抽象是将多种具体的东西 管理时需要遵守的规范 的共同点抽取出来 放入到更高一层的抽象层 在抽象层不定义或少
  • CentOS 7 关闭网络限制

    1 安装CentOS 7 3操作系统mini版本即可 2 设置关闭Selinux 编辑 etc selinux config vi etc selinux config SELINUX disabled 重启机器 查看selinux状态 s
  • mapengpeng1999@163.com 操作系统4~处理机调度

    处理机调度 1 三级调度体系 1 处理机调度主要是对处理机运行时间进行分配 即 按照一定算法或策略 将处理机运行时间分配给各个并发进程 同时尽量提高处理机的使用效率 2 现代操作系统中 按调度所实现的功能分3种类型 高级调度 中级调度和低级
  • 设备管理过程

    复杂度2 5 机密度2 5 最后更新2021 04 19 AIX中对设备会有如下五个操作 define aix下能看到设备的定义 但驱动程序并没有加载或初始化 该设备不可用 lsdev看到设备时defined 很多逻辑设备 vg lv等 只
  • JSON.stringify()

    JSON stringify 将一个JavaScript值 对象或者数组 转换为一个 JSON字符串 如果指定了replacer是一个函数 则可以选择性的替换值 或者如果指定了replacer是一个数组 可选择性的仅包含数组指定的属性 语法
  • Linux,Network manager 导致节点异常重启

    推断是Network manager 导致的 原因待查今天在VmWare的虚拟机上装了个测试RAC 又遇到了一个摸不到头绪的问题CRS装好后 一旦登陆图形界面 节点就重启 事情就有这么巧不登陆图形界面 观察了1个小时没问题 一旦登陆后 立刻
  • 《一个操作系统的实现》读书笔记-- 第一章--最小的“操作系统”

    一 最简单的 操作系统 最最简单的 操作系统 就是一个最最简单的引导扇区 Boot Sector 虽然它不具有任何功能 但是它却能够直接在裸机上运行 不依赖其他软件 一个引导扇区是512个字节 并且以0xAA55为结束标识的扇区 下面就是那
  • 操作系统 段页式存储管理

    一 引入 分页系统是以页面作为内存分配的基本单位 能有效地提高内存利用率 但信息共享等不方便 分段系统是以段作为内存分配的基本单位 它能够更好地满足用户多方面的需要 信息共享 动态链接等 但采用分区方式管理物理内存 仍然存在碎片问题 段页式
  • Ubuntu9.04太多乱码(中文不能正常显示)

    最近在使用Ubuntu9 04的过程中 发现有好多地方都出现乱码 其实是中文不能正常显示 现在把我所遇到的所有乱码问题集中一下 方便以后查阅参考 一 Flash乱码 在终端输入 sudo gedit etc fonts conf d 49
  • 《深入理解计算机系统》实验四Architecture Lab

    前言 深入理解计算机系统 实验四Architecture Lab下载和官方文档机翻请看 深入理解计算机系统 实验四Architecture Lab下载和官方文档机翻 我觉得这个文档对整个实验很有帮助 如果你的Y86 64环境还没安装好可以看
  • OS——文件管理系统磁盘的结构之搞清盘面和柱面

    如上图 每个柱面有三个盘面 即就是3个磁道 柱面可以抽象的理解成是一个套一个的立体的同心圆柱体 例 2019年408真题 磁盘有300个柱面 每个柱面有10个磁道 每个磁道有200个扇区 扇区大小为512B 则磁盘容量 分析 每个柱面有10
  • 由于回车符引起的shell错误

    今天弟弟写shell时出现一个错误 源代码如下 zip r 1 2 执行时出现错误 我也写了相同的语句 发现是可以执行的 把两个文件对比一看 差别在于 出错shell 正确shell 在linux下的回车是 n 在win下面的回车是 r n
  • linux 使用systemctl 启动服务报错: Error: No space left on device

    By default Linux only allocates 8192 watches for inotify which is ridiculously low And when it runs out the error is als
  • 磁盘调度算法笔记和练习题

    磁盘调度算法 先来先服务FCFS 最短寻道时间优先SSTF 扫描调度SCAN 练习题 先来先服务FCFS 最短寻道时间优先SSTF 扫描调度SCAN 它是一次只响应一个方向上的请求 这个方向上的请求都响应完了 再掉头处理另一个方向上的 有点
  • CentOS Linux服务器安全设置

    转自 http www osyunwei com archives 754 html 引言 我们必须明白 最小的权限 最少的服务 最大的安全 所以 无论是配置任何服务器 我们都必须把不用的服务关闭 把系统权限设置到最小话 这样才能保证服务器
  • MacOS中清除原有ssh公钥方法

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 用ssh的跳转登录服务器后 ssh会把你每个你访问过计算机的公钥 public key 都记录在 ssh known hosts 当下次访问相同计算机时 SSH会核对公钥
  • gdb attach 进程调试

    gdb调试正在运行的进程 GDB可以对正在执行的程序进行调度 它允许开发人员中断程序 并查看其状态 之后还能让这个程序正常地继续执行 gdb attach xxxxx xxxxx为利用ps命令获得的子进程process
  • 八股文打卡day20——操作系统(3)

    面试题 线程同步的方式有哪些 我的回答 多线程同时访问和修改某个数据的话 会造成数据的不一致和冲突问题 所以就需要线程同步 线程同步的方式有 1 互斥锁 互斥锁就是 当一个资源被访问和操作时 会对这个资源加锁 把这个资源锁定 其他线程不能对

随机推荐

  • java远程调试_Java 远程调试原理(学习笔记)

    Java远程调试的原理 JDWP Java Debug Wire Protocol 两个VM之间通过debug协议进行通信 然后以达到远程调试的目的 两者之间可以通过socket进行通信 其中 调试的程序常常被称为debugger 而被调试
  • postgis中将数据库备份到其它数据库中还原

    1 备份数据库 可以用命令操作 pg dump U postgres h hostip d joint boot Fc gt D python Project PG data joint jar 2 创建新的数据库 可以在其它postgis
  • vCard和MECARD格式

    vcard和MECARD都是电子名片的格式 这几篇文章介绍都很详细 MECARD格式的电子名片简单介绍 链接1 链接2 vCard格式 链接 分割线 补充一个只有微信扫码时会出现的问题 不管是vCard还是MECARD 也不管vCard是2
  • SpringBoot优缺点分析

    Spring的优点分析 Spring是Java企业版 Java Enterprise Edition JEE 也称J2EE 的轻量级代替品 无需开发重量级的Enterprise JavaBean EJB Spring为企业级Java开发提供
  • java进阶一:java集合

    1 集合简介 集合和数组类似 都是储存元素的容器 数组像是静态容器 长度一旦创建就不能再改变 元素类型必须统一 只能通过下标去索引元素等 集合像是动态容器 集合的长度可以动态的改变 元素类型可以不一致 可以用某个映射的关系去索引元素等 ja
  • vue-admin-template学习(一)

    vue admin template学习 一 vue admin template 框架结构 克隆运行项目 vue admin template项目改造 一 分析登录请求的思路 请求路线 登录 创建axios实例 request拦截器 re
  • Java实现捕鱼达人附源码

    1 游戏原理 swing 多线程 事件监听 swing实现的界面的绘制 多线程实现产生多种鱼 实现鱼的游动 以及网的移动 事件监听实现鼠标捕鱼事件的捕获 2 主要类和方法解释 鱼 背景 网都是图片 之所有是动态的效果 因为线程或者鼠标移动引
  • 批量替换文件及文件夹名称(bat)

    echo off SetLocal EnableDelayedExpansion set p old 输入原字符 Set p new 输入新字符 先处理文件 For f delims i in dir s b a d do Set a nx
  • QT(5)—— Q_D 与 Q_Q QObject与 QObjectPrivate

    核心就是 QObject QObject QObjectPrivate dd QObject parent d ptr dd d ptr gt q ptr this 互指 template
  • Axios 简单使用指南

    概述 什么是 Axios Axios 是一个开源的基于 promise 的 HTTP 请求库 一般常用于浏览器和 node js 中 它能够在具有相同代码库的浏览器和 nodejs 中同时运行 在服务器侧 它利用服务器端原生的 node j
  • Qt QTabWidget的简单应用

    Tab控件的简介 选项卡由选项栏和页面区域两部分组成 一个选项卡关联一个相关的页面内容 选项栏默认放置在页面区域的上方 可以通过 TabPosition接口函数设置选项栏的位置 选项卡与对应的页面进行关联 显示当前页面时 其他页面的内容被隐
  • 基于OpenCV的人脸检测总结

    在CSDN上拜读大牛们的博文已有余月 感慨颇深 也有过写些博文聊表自己的理解 但恐自己才学浅薄而误人子弟 也就作罢 今天无意中在大神Rachel Zhang的博文中发现一首原创诗句 读完后就觉得其实之前自己的那些想法真是一叶障目 好诗篇胜过
  • blender boxCutter插件

    boxCutter可以用来进行bool运算 打开boxCutter 方法1 物体模式在舞台左侧选择boxCutter图标 方法2 物体模式按N 在舞台右侧的侧边栏里选择boxCutter 方法3 物体模式alt w 打开BoxCutter后
  • Vue高级进阶

    Vue高级进阶 事件总线 EventBus eventBus js文件 全局引用 事件发送 事件监听 注意 混入 Mixin 定义 混入优先级 事件总线 EventBus 在非父子组件中是无法直接通信的 在vue中除了vuex可以统一管理状
  • js 数组的处理方法之 splice 和 slice

    今天测试人员给我提了个bug 说是数据不对 我看了一下显示的数据 立马就发现是把删除的元素展示了出来 然后就想到 数组的处理方法写错了 把 slice 用成了 splice 想了想还是有必要把这个记录一下 提醒自己以后要细心 首先说一下今天
  • 非常简单的清除axios请求(vue,react通用)

    1 添加js文件 实现添加与删除接口的功能 import axios from axios class CancelToken 声明一个 Map 用于存储每个请求的标识 和 取消函数 static pending new Map 白名单 写
  • Vue使用消息订阅与发布实现组件通信

    1 消息订阅与发布是组件间通信的一种方式 使用与任意组件间的通信 2 使用步骤 2 1 安装pubsub npm i pubsub js 2 2 引入 import pubsub from pubsub js 2 3 接受数据 订阅 met
  • 常用的指标计算和术语

    TNR specificity rates 和TPR sensitivity rates TNR即为特异度 specificity rates true negative rate 描述识别出的负例占所有负例的比例 计算公式为 TNR TN
  • 个人github地址 https://github.com/Gerry1218

    2019独角兽企业重金招聘Python工程师标准 gt gt gt https github com Gerry1218 转载于 https my oschina net petsatan blog 792027
  • 【操作系统】内存管理(四)—— 内存的分配与回收(2)

    操作系统 内存管理 四 内存的分配与回收 2 一 非连续分配管理方式 一 基本分页存储管理 1 分页 2 重要的数据结构 页表 3 基本分页式的基本地址变换机构 逻辑地址到物理地址的转换 4 页表项的大小 5 具有快表的地址变换机构 快表