内存分配算法-(首次分配法和最佳分配法)

本文介绍了内存分配的两种算法:首次分配法(first-fit)和最佳分配法(best-fit),并提供了C语言实现。通过空闲区链表管理内存,初始化后按首地址排序。首次分配法从空闲区中选取第一个足够大的空间分配,最佳分配法则寻找与所需大小最接近的空闲区进行分配。同时,文章还包含了内存释放及空闲区合并的功能。
摘要由CSDN通过智能技术生成
/* implement a memory allocation scheme by using algorithms first-fit, next-fit, and best-fit
 * freelist为空闲区链表的头,它的下一个节点才指向空闲缓冲区
 * freelist是按首地址来排序的,而不是按size来排序。按首地址排序便于相邻空闲内存合并;按size大小来排序,便于分配内存
 */
#include<stdio.h>
#include<stdlib.h>

#define N 	100

typedef enum {FALSE, TRUE} bool;

typedef struct node
{
	char *ptr; //start addr 指向mem处开始的地址
	int size; //size of the free block
	struct node *next; //next free block
}node;

char mem[N]; //total memory pool
node freelist; //head of free list, no value

/* init freelist to contain the whole mem */
void init()
{
	node *ptr = (node *)malloc(sizeof(node));
	ptr->ptr = mem;
	ptr->size = N;
	ptr->next = NULL;
	freelist.next = ptr;
}

/* remove a node ptr from the list whose previous node is prev */
void removenode(node *ptr, node *prev)
{	
	prev->next = ptr->next;
	free(ptr);
}

/* 首次适配法:从自由空闲区中选取第一个合适空闲区来分配 
 * 返回分配内存区首地址
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值