动态内存分配之伙伴算法

news2024/10/7 14:33:42

伙伴算法

伙伴算法是一种在计算机内存管理中使用的算法,用于分配和释放内存。它是一种基于二叉树的动态内存分配算法,可以高效地分配和合并内存块。伙伴算法是一种按照固定大小分配内存的算法,例如,每个内存块的大小为2的n次幂,即1、2、4、8、16、32等等。

伙伴算法的主要思想是将可用内存划分成多个大小相等的内存块,每个内存块大小为2的n次幂。对于每个内存块,都有一个伙伴内存块,它的大小是相等的,但是地址不同。例如,如果有一个大小为4个字节的内存块,它的伙伴内存块大小也为4个字节,但是它的地址不同。

当需要分配内存时,伙伴算法将查找大小最接近请求大小的可用内存块。如果找到的内存块大小正好匹配请求大小,则将其标记为已用,并返回指向该内存块的指针。如果找到的内存块比请求大小大,则将其拆分成两个相等的伙伴内存块,并将其中一个标记为已用,另一个标记为可用。然后,继续在较小的伙伴块中查找可用内存块,直到找到大小匹配的块或搜索完整个内存区域。

当需要释放内存时,伙伴算法将标记为已用的内存块标记为可用,并将其与其伙伴内存块合并。如果伙伴内存块也是可用的,则将它们合并成一个更大的内存块,直到合并到最大的内存块为止。在合并时,伙伴算法通过一个二叉树来管理内存块,每个节点表示一个内存块,节点的左子节点是伙伴内存块。

伙伴算法的优点是分配和释放内存的效率比较高,合并内存块的操作也比较简单。但是,由于它只能分配大小相等的内存块,因此可能会导致内存浪费。此外,它也可能导致内存碎片的问题。

能否避免内存碎片?

伙伴算法无法完全避免内存碎片,但可以减少碎片的数量和大小。

伙伴算法通过将可用内存空间划分为二的指数次幂大小的块,然后以块为单位分配和释放内存。分配请求按指数次幂进行舍入,以便可以分配给与请求大小最接近但不小于请求大小的可用块。如果没有完全匹配,就将块拆分为更小的块,然后继续寻找匹配项。当释放内存时,会找到相邻的空闲块并合并它们,以创建更大的空闲块。

尽管伙伴算法减少了碎片的数量和大小,但仍可能发生内存碎片。例如,如果有大量小型内存请求,可能会导致大量小块的分配和释放,这些小块可能无法合并成更大的块。此外,如果存在大小不一的块,则无法在它们之间进行合并。因此,伙伴算法无法消除所有内存碎片,但可以降低其影响。

内部碎片与外部碎片

内部碎片指的是已分配的内存空间中,未被使用的小块内存。这些内存块的大小小于分配的内存大小。例如,如果分配了一个 10MB 的空间来存储 1MB 的数据,则剩余的 9MB 就是内部碎片。

外部碎片指的是已分配的内存空间中,由于分配和释放的顺序不同导致的空隙,这些空隙可能很小,但无法被利用。例如,如果分配了两个 5MB 的内存块,但它们之间有一个 1MB 的空隙,这个空隙就是外部碎片。

【最后一个bug】多平台都有更新和发布,大家可以一键三连,关注+星标,不错过精彩内容~
在这里插入图片描述

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

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

相关文章

MyBatis学习笔记(十二) —— MyBatis的逆向工程

12、MyBatis的逆向工程 正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的。 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源: Java实体类Mappe…

操作系统--基于Linux的常用命令(超详细/设计/实验/作业/练习)

目录课程名:操作系统原理及Linux应用内容/作用:设计/实验/作业/练习学习:基于Linux的常用命令一、前言二、环境与设备三、原理四、内容五、总结与分析课程名:操作系统原理及Linux应用 内容/作用:设计/实验/作业/练习 …

苹果和富士康坚持推进印度制造,过于一厢情愿了,或加速衰退

在印度生产iPhone面临重重波折后,苹果和富士康仍然执意推进印度制造,这对于本已面临诸多风波的苹果来说并非好事,或许会加速苹果的衰退,毕竟如今的苹果早已没有当年的影响力了。一、苹果面临的问题苹果能成为智能手机市场的领导者…

【专项训练】排序算法

排序算法 非比较类的排序,基本上就是放在一个数组里面,统计每个数出现的次序 最重要的排序是比较类排序! O(nlogn)的3个排序,必须要会!即:堆排序、快速排序、归并排序! 快速排序:分治 经典快排 def quickSort1(arr

WinRAR安装教程

文章目录WinRAR安装教程无广告1. 下载2. 安装3. 注册4. 去广告WinRAR安装教程无广告 1. 下载 国内官网:https://www.winrar.com.cn/ 2. 安装 双击,使用默认路径: 点击“安装”。 点击“确定”。 点击“完成”。 3. 注册 链接&#xff…

第161篇 笔记-去中心化的含义

本文主要内容来自Vitalik Buterin的文章。“去中心化”这个词是在加密经济学领域用得最多的一个词,通常也作为辨别区块链的依据。然而,这个词也可能是被定义得最不恰当的一个词。数千小时的研究和价值数十亿美元哈希算力的投入都旨在实现去中心化&#x…

wsl ubuntu22.04 conda环境安装labelImg解决xcb缺失问题

labelImg 安装 pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/ pip install pyqt5-tools -i https://pypi.tuna.tsinghua.edu.cn/simple/ pip install lxml -i https://pypi.tuna.tsinghua.edu.cn/simple/ pip install labelImg -i https://pypi.tuna.tsingh…

Java基础学习(2)

Java基础学习一 基础概念1.1 注释1.2 关键字1.3 字面量特殊字符1.4 变量1.5 数据类型1.6 标识符1.7 键盘输入二 运算符隐式转换强制转换三元运算符运算符的优先级二 源码 补码 反码2.1 源码2.2 反码2.3 补码其他运算符逻辑与逻辑或左移右移一 基础概念 1.1 注释 对自己所写的内…

HTML快速入门

目录HTML概念HTML基本格式基本语法常用标签1.文件标签:构成html最基本的标签2.文本标签:和文本有关的标签3.列表标签4.图片标签5.超链接标签6.表格标签7.表单标签HTML概念 HTML是最基础的网页开发语言,Hyper Text Markup Language&#xff0…

保姆级使用PyTorch训练与评估自己的Replknet网络教程

文章目录前言0. 环境搭建&快速开始1. 数据集制作1.1 标签文件制作1.2 数据集划分1.3 数据集信息文件制作2. 修改参数文件3. 训练4. 评估5. 其他教程前言 项目地址:https://github.com/Fafa-DL/Awesome-Backbones 操作教程:https://www.bilibili.co…

cocoscreator打包android app bundle使用Play Asset Delivery分包

1.cocoscreator构建完android项目 2.用androidstudio打开项目 3.点击androidstudio上项目目录左上角的Android改为Project 4. 在项目目录下新建Modul 5.选择Android Library 6.命名assetPack1或者自定义,点击Finish 7.在新建的assetPack1目录下找到build.gradle并…

【408数据结构】一篇文章吃透算法时间复杂度

文章目录前言1. 什么是好的算法2. 算法的效率度量3. 时间复杂度4. 大 O 时间复杂度表示法5. 算法时间复杂度计算规则🍑 规则 1:只关注循环中的代码段🍑 规则 2:加法规则🍑 规则 3:乘法规则6. 常见算法时间复…

两道有关链表的练习

目录 一、分割链表 二、奇偶链表 一、分割链表 给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。 你不需要 保留 每个分区中各节点的初始相对位置。 示例 1: 输…

国科大论文latex模板中可能的注意事项

背景 国科大2022年9月发布了毕业论文的LaTeX模板,它是在ucasthesis上修改而来的,但近日使用国科大发布版本时发现有几点不同以及需要注意的地方。本人只会简单使用latex,但并不熟悉latex样式编辑,因此以下介绍与方法仅供参考。仅…

基于 Flink CDC 的实时同步系统

摘要:本文整理自科杰科技大数据架构师张军,在 FFA 2022 数据集成专场的分享。本篇内容主要分为四个部分:功能概述架构设计技术挑战生产实践Tips:点击「阅读原文」查看原文视频&演讲 ppt科杰科技是专门做大数据服务的供应商&am…

Regmap API 实验

目录 一、Regmap regmap 结构体 regmap_config 结构体 regmap_config 掩码设置 二、Regmap 操作函数 1、Regmap 申请与初始化 2、 regmap 设备访问 API 函数 3、regmap_update_bits 函数 4、regmap_bulk_read函数 5、regmap_bulk_write 三、修改SPI实验 1、添加regmap…

Kubenates中的日志收集方案ELK(下)

1、rpm安装Logstash wget https://artifacts.elastic.co/downloads/logstash/logstash-6.8.7.rpm yum install -y logstash-6.8.7.rpm2、创建syslog配置 input {beats{port> 5044 } }output {elasticsearch {hosts > ["http://localhost:9200"]index …

【博客632】k8s service ession affinity原理与iptables recent模块

k8s service ession affinity原理与iptables recent模块 1、iptables recent模块 作用: iptables的recent模块用于限制一段时间内的连接数, 是谨防大量请求攻击的必杀绝技! 善加利用该模块可充分保证服务器安全。 recent常用参数: –name 设定列表名称…

Git使用教程:最详细、最傻瓜、最浅显、真正手把手教

GITGIT版本控制版本控制的意义分布式图形化客户端环境搭建仓库的操作分支使用场景命令远程仓库操作生成公钥命令冲突忽略列表的配置时机配置方式版本回退练习:GIT 版本控制 把文件系统中的文件,按照修改的版本进行记录,进行管理的操作。 版…

Spring Cloud ( Consul注册、发现 )

操作步骤: 安装Consul服务端在服务内添加客户端依赖修改配置类,添加注解编写yml文件一、安装Consul服务端 链接:https://www.consul.io/downloads.html,解压 开启cmd,进入你的Consul解压路径,我是在E盘 …