【C 数据结构-动态内存管理】3. 伙伴系统管理动态内存

news2025/1/19 8:12:33

文章目录

  • 【 1. 伙伴系统的结构设计 】
  • 【 2. 分配算法 】
  • 【 3. 回收算法 】

  • 伙伴系统 本身是一种动态管理内存的方法,和边界标识法的区别是:使用伙伴系统管理的存储空间,无论是空闲块还是占用块,大小都是 2 的 n 次幂(n 为正整数)。
    例如,系统中整个存储空间为 2 m 2^m 2m 个字。那么在进行若干次分配与回收后,可利用空间表中只可能包含空间大小为: 2 0 2^0 20 2 1 2^1 21 2 2 2^2 22、…、 2 m 2^m 2m 的空闲块。

【 1. 伙伴系统的结构设计 】

  • 伙伴系统中可利用空间表中的结点构成如下图所示:
    header 域表示为头部结点,由 4 部分构成:
    • llinkrlink 为结点类型的指针域,分别用于指向直接前驱和直接后继结点。
    • tag :用于标记内存块的状态,是占用块(用 1 表示)还是空闲块(用 0 表示)
    • kval :记录该存储块的容量。由于系统中各存储块都是 2 的 m 幂次方,所以 kval 记录 m 的值。
      在这里插入图片描述
  • 伙伴系统节点的 C 实现:
typedef struct WORD_b{
    struct WORD_b *llink;//指向直接前驱
    int tag;//记录该块是占用块还是空闲块
    int kval;//记录该存储块容量大小为2的多少次幂
    struct WORD_b *rlink;//指向直接后继
    OtherType other;//记录结点的其它信息
}WORD_b,head;
  • 在伙伴系统中,由于系统会不断地接受用户的内存申请的请求,所以会产生很多大小不同但是容量都是为 2 m 2^m 2m 的内存块,所以为了在分配的时候查找方便,系统将大小相同的内存块建立一个链表。对于初始容量为 2 m 2^m 2m 的一整块存储空间来说,形成的链表就有可能有 m+1 个,为了更好的对这些链表进行管理,系统将这 m+1 个链表的表头存储在数组中,就类似于邻接表的结构,如下图所示:
    在这里插入图片描述
  • 可利用空间表的 C 实现:
#define m 16//设定m的初始值
typedef struct HeadNode {
    int nodesize;//记录该链表中存储的空闲块的大小
    WORD_b * first;//相当于链表中的next指针的作用
}FreeList[m+1];//一维数组

【 2. 分配算法 】

  • 伙伴系统的分配算法很简单。假设用户向系统申请大小为 n 的存储空间,若 2 k − 1 < n ≤ 2 k 2^{k-1} < n \leq 2^k 2k1<n2k,此时就需要查看可利用空间表中大小为 2 k 2^k 2k 的链表中有没有可利用的空间结点:
    • 如果该链表不为 NULL,可以直接采用头插法从头部取出一个结点,提供给用户使用;
    • 如果大小为 2k 的链表为 NULL,就需要依次查看比 2 k 2^k 2k 大的链表,找到后从链表中删除,截取相应大小的空间给用户使用,剩余的空间,根据大小插入到相应的链表中。
  • 例如,用户向系统申请一块大小为 7 个字的空间,而系统总的内存为 24 个字,则此时按照伙伴系统的分配算法得出: 2 2 2^2 22 < 7 < 2 3 2^3 23,所以此时应查看可利用空间表中大小为 2 3 2^3 23 的链表中是否有空闲结点:
    • 如果有,则从该链表中摘除一个结点,直接分配给用户使用;
    • 如果没有,则需依次查看比 2 3 2^3 23 大的各个链表中是否有空闲结点。假设,在大小 2 4 2^4 24 的链表中有空闲块,则摘除该空闲块,分配给用户 2 3 2^3 23 个字的空间,剩余 2 3 2^3 23 个字,该剩余的空闲块添加到大小为 2 3 2^3 23 的链表中,如下图所示:
      在这里插入图片描述
  • 使用伙伴系统进行存储空间的管理过程中,在用户申请空间时,由于大小不同的空闲块处于不同的链表中,所以 分配完成的速度会更快,算法相对简单

【 3. 回收算法 】

  • 无论使用什么内存管理机制,在内存回收的问题上都会面临一个共同的问题:如何把回收的内存进行有效地整合,伙伴系统也不例外。
  • 当用户申请的内存块不再使用时,系统需要将这部分存储块回收,回收时需要判断是否可以和其它的空闲块进行合并。在寻找合并对象时,伙伴系统和边界标识法不同,在伙伴系统中每一个存储块都有各自的 伙伴当用户释放存储块时只需要判断该内存块的伙伴是否为空闲块,如果是则将其合并,然后合并的新的空闲块还需要同其伙伴进行判断整合,反之直接将存储块根据大小插入到可利用空间表中即可
  • 判断一个存储块的伙伴的位置时,采用的方法为:如果该存储块的起始地址为 p,大小为 2 k 2^k 2k,则其伙伴所在的起始地址为:
    { p + 2 k ,若 p 取余 2 k + 1 = 0 p − 2 k ,若 p 取余 2 k + 1 = 2 k \begin{cases} p+2^k,若p取余2^{k+1}=0\\\\ p-2^k,若p取余2^{k+1}=2^k\end{cases} p+2k,若p取余2k+1=0p2k,若p取余2k+1=2k
  • 例如,当大小为 2 8 2^8 28 ,起始地址为 512 的伙伴块的起始地址的计算方式为:
    由于 512 取余 2 9 2^9 29=0,所以,512+ 2 8 2^8 28=768,即如果该存储块回收时,只需要查看起始地址为 768 768 768 的存储块的状态,如果是空闲块则两者合并,反之直接将回收的释放块链接到大小为 2 8 2^8 28 的链表中。
  • 回收存储空间时,对于 空闲块的合并,不是取决于该空闲块的相邻位置的块的状态;而是 完全取决于其伙伴块。所以即使其相邻位置的存储块时空闲块,但是由于两者不是伙伴的关系,所以也不会合并。这也就是该系统的缺点之一:由于 在合并时只考虑伙伴,所以容易产生存储的碎片

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1674351.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

干电池升压芯片PW5100:高效转换,赋能小型设备

内容简述目录&#xff1a; 1&#xff0c;干电池的工作电压范围 2&#xff0c;平芯微根据干电池规格书整理的干电池输出电流性能表 3&#xff0c;干电池负载能力的理解和解释 4&#xff0c;专用干电池升压芯片 PW5100 5&#xff0c;干电池升压芯片采用 0603,0805,1206 电感和输出…

多模态大语言模型的演化:综述

24年2月意大利三所研究大学和机构的论文“The Evolution of Multimodal Large Language Models: A Survey”。 连接文本和视觉模态在生成智能中起着至关重要的作用。由于这个原因&#xff0c;在大语言模型成功的启发下&#xff0c;大量的研究工作被投入到多模态大语言模型&…

Python框架篇(9):FastApi-SQLAlchemy集成

1. 介绍 ORM框架将数据库中的表&#xff08;表结构&#xff09;映射为面向对象的类&#xff08;对象&#xff09;&#xff0c;将表中的记录&#xff08;行&#xff09;映射为类的实例&#xff08;对象的实例&#xff09;&#xff0c;将表中的字段&#xff08;列&#xff09;映…

Oracle21c数据库普通用户创建及授权,建表,创建存储过程、序列、触发器

一、Oracle数据库错误 ORA-65096 表示你尝试在多租户容器数据库&#xff08;CDB&#xff09;环境中创建一个公共用户&#xff08;common user&#xff09;或角色&#xff0c;但没有使用正确的前缀。在多租户架构中&#xff0c;公共用户的用户名必须以 C## 或 c## 开头。 若想…

Linux|基础IO

回顾c语言的文件操作 #include<stdio.h> int main() { FILE * fp fopen("test.txt","w"); if(fp NULL) return -1;fwrite(message,strlen(message),1,fp); fclose(fp); return 0; } 我们我们以写的方式打开 不存在则创建…

Kubernetes——CNI网络组件

目录 一、Kubernetes三种接口 二、Kubernetes三种网络 三、VLAN与VXLAN 1.VLAN 2.VXLAN 3.区别 3.1作用不同 3.2vxlan支持更多的二层网络 3.3已有的网络路径利用效率更高 3.4防止物理交换机Mac表耗尽 3.5相对VLAN技术&#xff0c;VXLAN技术具有以下优势 四、CNI网…

爱普生M-A352加速度计受到日本气象厅认证

地震一直是缠在人们头顶的乌云&#xff0c;如何能在地震发生的时候提前获悉&#xff0c;防止造成更大的经济损失&#xff0c;成为了许多企业准备解决的问题。精工爱普生公司获悉&#xff0c;东京Knowledge ForesightInc.生产的配备爱普生M-A352 高性能三轴加速度计的“Yure Mon…

灌区信息化管理平台系统包含哪些内容?(全面介绍)

政策背景 2022年12月29日&#xff0c;水利部启动48处大中型灌区开展数字孪生灌区先行先试建设。 2023年2月24日&#xff0c;《2023年农村水利水电工作要点》:2023年农村水利水电工作的总体思路包括:紧盯保障国家粮食安全&#xff0c;加快推进大中型灌区现代化改造&#xff0c;…

传说中的运维门户设计

在IT服务管理这片广阔天地中&#xff0c;运维门户如同一位技艺高超的魔术师&#xff0c;轻轻一挥手&#xff0c;便将纷繁复杂的运维世界化繁为简&#xff0c;编织成一张便捷高效、触手可及的网络。它不仅是ITSM系统中不可或缺的一环&#xff0c;更是连接用户与技术世界的桥梁&a…

mars3d实现gltf模型new mars3d.graphic.ModelPrimitive({的自定义shader

原模型展示&#xff1a; 自定义shader效果展示&#xff1a; 运动状态下&#xff1a; 关键代码&#xff1a; const pointCloudWaveShader new Cesium.CustomShader({uniforms: {u_time: {type: Cesium.UniformType.FLOAT,value: 0}},vertexShaderText: void vertexMain(Vertex…

【全开源】房屋出租出售预约系统支持微信小程序+H5+APP

一款基于FastAdminThinkPHPUniapp开发的房屋出租出售预约系统&#xff0c;支持小程序、H5、APP&#xff1b;包含房客、房东(高级授权)、经纪人(高级授权)三种身份。核心功能有&#xff1a;新盘销售、房屋租赁、地图找房、小区找房&#xff0c;地铁找房等方式。 特色功能&#…

XML解析 之 DomFourJ解析

1&#xff0c;DomFourJ干嘛的&#xff1f; 百度一搜一大堆而且说的很繁琐&#xff0c;在这总结一句话&#xff1a; dom4j就是一个Java用来读写XML文件的API&#xff0c;而且简单又方便还好用 2&#xff0c;什么时候用&#xff1f; 不管读取什么XML文档只要你想用就用没啥限制…

浅谈工业用LED面光源

在机器视觉系统中&#xff0c;光源作为不可或缺的一部分&#xff0c;能够提高目标成像效果&#xff0c;增强检测效果。光源的选择至关重要&#xff0c;选到不合适的会影响成像及检测效果。针对不同的检测对象,不同的形状光源应运而生。我们来看看最常用的LED光源之一——面光源…

『 Linux 』重定向 Redirect(万字)

文章目录 &#x1f9f8; 什么是重定向&#x1f421; 文件描述符的分配规则&#x1f421; 重定向在日常使用中的简单示例 &#x1f9f8; 实现重定向的底层机制&#x1f421; dup2()&#x1f421; 利用dup2()实现重定向 &#x1f9f8; 在自定义Shell当中添加重定向功能&#x1f4…

【Neo4jJDK开箱即用的安装全流程】

neo4j:命令行本地访问loclhost neo4j:命令行本地访问loclhost2 neo4j操作 Neo4j桌面版数据库导出导入 Neo4j安装与配置以及JDK安装与配置教程&#xff08;超详细&#xff09; Neo4j 安装、使用教程 Neo4j安装教程 Neo4J桌面版的配置和连接Pycharm jdk-neo对应版本 JDK ORACLE中…

2024/5/14 英语每日一段

“It is important as it suggests that possibly several populations in the world already started to include substantial amount of plants in their diet” in the period before agriculture was developed, a view contradictory to the popular one, added archeo-ge…

全网最通俗易懂的vue透传

概念&#xff1a; Vue的透传是指在Vue组件中&#xff0c;使用特定的语法将父组件传递的属性或事件直接传递给子组件&#xff0c;实现了通过父组件传递数据或事件&#xff0c;再传递给子组件的功能。&#xff08;传递给一个组件&#xff0c;却没有被该组件声明为 props 或 emit…

2024年前一季度,国内医疗器械营收TOP10出炉!

随着国内医疗器械市场的不断发展&#xff0c;各大医疗器械公司的财报数据成为了投资者和行业观察者关注的焦点。近日&#xff0c;根据2024年第一季度财报数据&#xff0c;我们梳理出了中国医疗器械第一财季营收排名前十的械企&#xff0c;为大家带来深入的分析和解读。 一、营…

算法课程笔记——路径相关树形DP

算法课程笔记——路径相关树形DP #include<bits/stdc.h>usingnamespacestd; usingLL longlong; constintN 2005; vector<int>e[N],t; structasdf{vector<int> vec; LL val; }; vector<asdf>w[N]; LL dp[N]; intn,m,k,dep[N]{1},f[N]; voiddfs(in…

图生视频,Stable Diffusion WebUI Forge内置SVD了!

在 Stable Diffusion WebUI Forge 版本中内置了一个SVD插件&#xff0c;也就是 Stable Video Diffusion&#xff08;稳定视频扩散&#xff09;&#xff0c;之前我介绍过这个工具的使用方法&#xff1a;图片生成视频&#xff08;独立部署SVD) 但是当时还不能集成到Stable Diffu…