c语言储存空间的函数是 c语言的内存空间储存( 三 )


在讨论分配内存之前,我们将先讨论释放 , 因为它更简单 。为了释放内存 , 我们必须要做的惟一一件事情就是,获得我们给出的指针,回退 sizeof(struct mem_control_block) 个字节,并将其标记为可用的 。这里是对应的代码:
清单 4. 解除分配函数
void free(void *firstbyte) {
struct mem_control_block *mcb;
mcb = firstbyte - sizeof(struct mem_control_block);
mcb-is_available = 1;
return;
}
如您所见,在这个分配程序中,内存的释放使用了一个非常简单的机制 , 在固定时间内完成内存释放 。分配内存稍微困难一些 。我们主要使用连接的指针遍历内存来寻找开放的内存块 。这里是代码:
//清单 6. 主分配程序
void *malloc(long numbytes) {
void *current_location;
struct mem_control_block *current_location_mcb;
void *memory_location;
if(! has_initialized) {
malloc_init();
}
numbytes = numbytes + sizeof(struct mem_control_block);
memory_location = 0;
current_location = managed_memory_start;
while(current_location != last_valid_address)
{
current_location_mcb =
(struct mem_control_block *)current_location;
if(current_location_mcb-is_available)
{
if(current_location_mcb-size = numbytes)
{
current_location_mcb-is_available = 0;
memory_location = current_location;
break;
}
}
current_location = current_location +
current_location_mcb-size;
}
if(! memory_location)
{
sbrk(numbytes);
memory_location = last_valid_address;
last_valid_address = last_valid_address + numbytes;
current_location_mcb = memory_location;
current_location_mcb-is_available = 0;
current_location_mcb-size = numbytes;
}
memory_location = memory_location + sizeof(struct mem_control_block);
return memory_location;
}
这就是我们的内存管理器 。现在,我们只需要构建它 , 并在程序中使用它即可.多次调用malloc()后空闲内存被切成很多的小内存片段,这就使得用户在申请内存使用时,由于找不到足够大的内存空间 , malloc()需要进行内存整理,使得函数的性能越来越低 。聪明的程序员通过总是分配大小为2的幂的内存块,而最大限度地降低潜在的malloc性能丧失 。也就是说 , 所分配的内存块大小为4字节、8字节、16字节、 18446744073709551616字节,等等 。这样做最大限度地减少了进入空闲链的怪异片段(各种尺寸的小片段都有)的数量 。尽管看起来这好像浪费了空间,但也容易看出浪费的空间永远不会超过50% 。
【c语言储存空间的函数是 c语言的内存空间储存】c语言储存空间的函数是的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于c语言的内存空间储存、c语言储存空间的函数是的信息别忘了在本站进行查找喔 。

推荐阅读