您的位置:首页 > 运维架构 > Linux

[Linux内存]linux内存分配函数总结

2015-01-26 20:07 225 查看
linux内核相关

1,linux内核内存分配函数总结

单位接口算法
动态大小kmalloc/kfree/krealloc/kcalloc按大小组织的缓存数组
固定大小kmem_cache_create/kmem_cache_destroy
kmem_cache_alloc/kmem_cache_free
Slab[2]
2^n页alloc_pages/free_pages
__get_free_pages/__free_pages
伙伴算法,分配若干(物理连续)页面,返回指向该区域第一个字节的指针
vmalloc
工作方式类似于kmalloc(), 不过虚拟地址连续,物理地址不连续。获得大块内存时使用,通常在creat_module()系统调用的地方使用。

2,各种API应用举例

kmem_cache_create和kmem_cache_alloc,比如在Namespace.c文件的mnt_int()函数中调用kmem_cache_creat()函数创建名为mnt_cache的缓存,然后在调用do_mount()函数的时候调用kmem_cache_alloc()函数分配一个mount结构体。

用户层相关:

3,malloc和calloc函数

void *calloc(size_t n, size_t size);

在内存的动态存储区中分配n个长度为size的连续空间,函数返回一个指向分配起始地址的指针;如果分配不成功,返回NULL。calloc在动态分配完内存后,自动初始化该内存空间为零,而malloc不初始化,里边数据是随机的垃圾数据。
extern void *malloc(unsigned int num_bytes);
使用malloc()和calloc()函数分配的内存使用完以后一定要用free()函数将内存手动释放。

malloc()函数申请到的内存空间在什么范围:答:0X00000000到0XBFFFFFFF

4,linux内核有些地方分配内存不允许失败,这个时候应该如何保证

答:使用内存池技术,内存池本质也是后背高速缓存,只是在使用前提前准备好,缺点是浪费内存。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: