操作系统:连续内存分配

操作系统在加载程序和处理数据时需要连续内存分配。内存分配包括静态和动态两种,动态分配允许程序运行时按需申请和释放内存。常见的内存分配策略有首次适应、最佳适应和最差适应,其中首次适应通常效率最高,但可能导致内存碎片。最佳适应和最差适应虽然在某些方面有理论优势,但在实践中可能产生更多外部碎片,影响性能。
摘要由CSDN通过智能技术生成

 

OS在什么时候需要进行连续的内存空间分配?、

  • OS从硬盘提取程序数据到内存中的时候,需要在内存中分配一块连续的内存空间
  • 应用程序需要在内存中访问数据的时候,OS需要给数据分配一块连续的内存空间
  •  

内存分配有静态分配和动态分配两种, 静态分配在程序编译链接时分配的大小和使用寿命就已经确定,而应用上要求操作系统可以提供给进程运行时申请和释放任意大小内存的功能,这就是内存的动态分配。

 

OS需要知道内存空间中哪里是空闲去哪里是非空闲区进行分配管理,

  • 分配策略
  1. 首次适应适配(First Fit)
  2. 最佳适应适配(Best Fit)
  3. 最差适应适配(Worst Fit)

PS  : 内存碎片问题,内存碎片分为内部碎片与外部碎片,

内部碎片的产生:因为所有的内存分配必须起始于可被 4、8 或 16 整除(视处理器体系结构而定)的地址或者因为MMU的分页机制的限制,决定内存分配算法仅能把预定大小的内存块分配给客户。假设当某个客户请求一个 43 字节的内存块时,因为没有适合大小的内存,所以它可能会获得 44字节、48字节等稍大一点的字节,因此由所需大小四舍五入而产生的多余空间就叫内部碎片。

外部碎片的产生: 频繁的分配与回收物理页面会导致大量的、连续且小的页面块夹杂在已分配的页面中间,就会产生外部碎片。假设有一块一共有100个单位的连续空闲内存空间,范围是0~99。如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为0~9区间。这时候你继续申请一块内存,比如说5个单位大,第二块得到的内存块就应

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值