内存动态分区分配_Java实现四种动态内存分配方式

来点干货

本文是利用Java实现操作系统中的四种动态内存分配方式 ,分别是:

  • BF
  • NF
  • WF
  • FF

分两部分,第一部分是介绍四种分配方式的概念以及例子,第二部分是代码实现以及讲解。

四种分配方式

概念

操作系统中有一个动态分区分配的概念,内存在初始化的时候不会划分区域,而是在进程装入的时候,根据所要装入的进程动态地对内存空间进行划分,以提高内存空间的利用率,降低碎片的大小,主要的方法有一下四种:

  • 首次适应算法(First Fit):从空闲分区链首开始查找,直到找到一个满足其大小要求的空闲分区为止
  • 循环首次适应算法(Next Fit):从上次找到的空闲分区的下一个开始查找
  • 最佳适应算法(Best Fit):把空闲分区按大小递增的方式形成分区链,找到第一个能满足要求的空闲分区就进行分配
  • 最坏适应算法(Worst Fit):与最佳适应算法相反,把空闲分区按大小递减的方式形成分区链,找到第一个能满足要求的空闲分区就进行分配

例子

假设现在有100MB的内存空间,某一时刻先后分配了20MB4MB10MB内存,示意图如下:

abacbea3504b489b40c5504bd14d880c.png

现在需要再分配5MB内存。

若采用FF,因为FF是直接按顺序分配内存,从低地址开始搜索空闲分区,因此便会从第一块空闲分区分配5MB(地址0-5),示意图:

e14894489f0e99024f23b3eac2b9d832.png

若采用NFNFFF类似,只不过NF是从上一次找到的空闲分区的下一块开始查找,因为上一次分配的是10MB,因此会从最后一块空闲分区(地址80-100)分配内存:

2ee4f4fbd8dbbad70ca6038bd4a39e32.png

若采用BFBF是遍历所有空闲分区并找到一个能满足要求的最小分区,也就会找到一个比5MB大的空闲分区,且该空闲分区是所有空闲分区中最小的,也就是地址为64-70的空闲分区:

0182410fc906eaf35412a2faa5310be7.png

若采用WFWFBF相反,总是从最大的空闲分区开始分配,因此会从地址为30-60的空闲分区进行分配:

bfa0f549079c4b97f13c0508566a4fae.png

代码实现

总览

代码分成了四个类:

9b92995a402061ae063a293b9d5c555a.png
  • Main:测试
  • Print:输出打印
  • Table:表示每一个分区
  • TableList:对分区进行控制,包括初始化,分配,回收等

Main

Main是测试类,代码如下:

public class Main {
     

    private final static TableList list = new TableList(64);

    public static void main(String[] args) {
        list.useWF();
//        list.useBF();
//        list.useNF();
//        list.useFF();

        list.allocate(10);
        list.allocate(20);
        list.free(10);
        list.
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值