求brk()函数的详细资料,Linux平台下的,要求有示例。

求brk()函数的详细资料,Linux平台下的,要求有示例。,第1张

不要怪我复制粘贴,这个百度里面就有啊 。。函数名: brk

功 能: 改变数据段空间分配

用 法: int brk(void *endds)

头文件:#include<stdlib.h>

程序例:

#include <stdio.h>

#include <alloc.h>

int main(void)

{

char *ptr

printf("Changing allocation with brk()\n")

ptr = malloc(1)

printf("Before brk() call: %lu bytes free\n", coreleft())

brk(ptr+1000)

printf(" After brk() call: %lu bytes free\n", coreleft())

return 0

}

Linux内核运行在X86机器的物理内存管理使用简单平坦内存模型,每个用户进程内存(虚拟内存)地址范围为从0到TASK_SIZE字节,超过此内存的限制不能被用户访问。用户进程被分为几个逻辑段,成为虚拟内存区域,内核跟踪和管理用户进程的虚拟内存区域提供适当的内存管理和内存保护处理。do_brk()是一个内核函数,用于间接调用管理进程的内存堆的增加和缩减 (brk),它是一个mmap(2)系统调用的简化版本,只处理匿名映射(如未初始化数据)。do_brk()改变进程的地址空间。地址是代表数据段结束的一个指针(事实上是进程的堆区域)。 do_brk()的参数是一个绝对逻辑地址,这个地址代表地址空间新的结尾。更实际地说,我们在编写用户程序的时候从来就不应该使用这个函数。使用这个函数的用户程序就不能再使用malloc(),这是一个大问题,因为标注库的许多部分依赖于malloc()。 如果在用户程序中使用do_brk()可能会导致难以发现的程序崩溃。do_brk(addr, len)函数给从addr到addr+len建立虚拟内存区vm_area_struct(该区的起始地址为addr;结束地址为addr+len),该虚拟内存区作为进程的堆来使用。 malloc将从此区域获取内存空间(虚拟内存), free()将会把malloc()获取的虚拟空间释放掉(归还到该进程的堆的空闲空间中去)


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/7098004.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-01
下一篇 2023-04-01

发表评论

登录后才能评论

评论列表(0条)

保存