Linux用户空间和内核空间所有15种内存分配方法

简介: Linux用户空间和内核空间所有15种内存分配方法

在Linux操作系统中,内存管理是一个关键的系统功能。用户空间和内核空间分别使用不同的函数来申请内存。以下是用户空间和内核空间内存申请函数的详细列表:

Linux用户空间内存申请函数

1. malloc() 函数:

void* malloc(size_t size);

用于在堆区分配一块指定大小的内存空间。如果成功分配,返回一个指向这块内存的指针;否则,返回`NULL`。

2. calloc() 函数:

void* calloc(size_t num, size_t size);

分配并初始化为0的一块连续内存空间。它会为`num`个大小为`size`的对象分配内存,并将所有字节初始化为0。

3. realloc() 函数:

void* realloc(void* ptr, size_t new_size);

改变之前通过`malloc()`或`calloc()`等函数分配的内存块的大小。它可以扩大或缩小已分配的内存区域。如果内存无法重新分配,则返回`NULL`,原有的内存区域保持不变。

4. alloca() 函数(非标准库函数,某些编译器支持):

void* alloca(size_t size);

在栈上动态分配内存。它的优点是不需要手动释放,但缺点是可能导致栈溢出。

5. 使用静态存储区:

在程序开始时就为其分配了内存,由编译器自动管理,生命周期从程序开始到结束。

6. 使用全局变量和局部静态变量:

全局变量在整个程序运行期间都存在,而局部静态变量只在声明它们的函数或代码块退出后才被销毁。

请注意,在使用这些函数分配内存之后,必须确保在不再需要该内存时调用相应的内存释放函数来释放它,以避免内存泄漏。对于`malloc()`、`calloc()`和`realloc()`分配的内存,应使用`free()`函数进行释放。

Linux内核空间内存申请函数

1. kmalloc() 函数:

void *kmalloc(size_t size, gfp_t flags);

分配指定大小的连续物理内存块,并返回指向该内存块的指针。`flags`参数用于控制内存分配的行为和特性。

2. vmalloc() 函数:

void *vmalloc(unsigned long size);

分配虚拟内存,而不是连续的物理内存。分配的内存可能分布在多个物理页面上,但对进程来说是连续的。

3. get_free_pages()和 __get_free_page()函数:

unsigned long get_free_pages(gfp_t gfp_mask, unsigned int order);

unsigned long __get_free_page(gfp_t gfp_mask);

这两个函数分别用于分配特定数量的连续物理页(以2的幂为单位)和单个物理页。`order`参数表示需要多少个连续的页,例如`order=0`代表一页。

4. alloc_pages(), __alloc_pages():

struct page *alloc_pages(gfp_t gfp_mask, unsigned int order);

struct page *__alloc_pages(gfp_t gfp_mask, unsigned int order);

与`get_free_pages()`类似,这些函数用于分配一组连续的物理页,但它们返回一个指向`struct page`结构体的指针列表。

5. alloc_page(), __alloc_page():

struct page *alloc_page(gfp_t gfp_mask);

struct page *__alloc_page(gfp_t gfp_mask);

分配一个单独的物理页,返回一个指向`struct page`的指针。

6. dma_alloc_coherent():

void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, gfp_t flag);

在设备映射区域分配一块连续的物理内存,以便于DMA传输。分配的内存对于处理器来说是可直接访问的,并且确保不会被内核抢占或迁移。

7. kzalloc():

void *kzalloc(size_t size, gfp_t flags);

类似于`kmalloc()`,但在分配内存后将其所有字节初始化为0。

8. kfree():

void kfree(const void *ptr);

释放通过上述内核内存分配函数分配的内存。

9. 其他特殊的内存分配函数

如`page_frag_cache()`、`__get_dma_pages()`等,用于满足特定场景的需求。

请注意,在使用这些函数时,应根据具体需求选择适当的内存分配函数,并遵循正确的使用规则,避免内存泄漏或其他问题。

目录
相关文章
|
15天前
|
并行计算 Linux
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
119 67
|
4天前
|
存储 Linux
Linux内核中的current机制解析
总的来说,current机制是Linux内核中进程管理的基础,它通过获取当前进程的task_struct结构的地址,可以方便地获取和修改进程的信息。这个机制在内核中的使用非常广泛,对于理解Linux内核的工作原理有着重要的意义。
26 11
|
24天前
|
监控 Linux Python
Linux系统资源管理:多角度查看内存使用情况。
要知道,透过内存管理的窗口,我们可以洞察到Linux系统运行的真实身姿,如同解剖学家透过微观镜,洞察生命的奥秘。记住,不要惧怕那些高深的命令和参数,他们只是你掌握系统"魔法棒"的钥匙,熟练掌握后,你就可以骄傲地说:Linux,我来了!
108 27
|
1月前
|
自然语言处理 监控 Linux
Linux 内核源码分析---proc 文件系统
`proc`文件系统是Linux内核中一个灵活而强大的工具,提供了一个与内核数据结构交互的接口。通过本文的分析,我们深入探讨了 `proc`文件系统的实现原理,包括其初始化、文件的创建与操作、动态内容生成等方面。通过对这些内容的理解,开发者可以更好地利用 `proc`文件系统来监控和调试内核,同时也为系统管理提供了便利的工具。
71 16
|
2月前
|
缓存 NoSQL Linux
Linux系统内存使用优化技巧
交换空间(Swap)的优化 禁用 Swap sudo swapoff -a 作用:这个命令会禁用系统中所有的 Swap 空间。swapoff 命令用于关闭 Swap 空间,-a 参数表示关闭 /etc/fstab 文件中配置的所有 Swap 空间。 使用场景:在高性能应用场景下,比如数据库服务器或高性能计算服务器,禁用 Swap 可以减少磁盘 I/O,提高系统性能。
57 3
|
1月前
|
存储 缓存 算法
JVM简介—1.Java内存区域
本文详细介绍了Java虚拟机运行时数据区的各个方面,包括其定义、类型(如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和直接内存)及其作用。文中还探讨了各版本内存区域的变化、直接内存的使用、从线程角度分析Java内存区域、堆与栈的区别、对象创建步骤、对象内存布局及访问定位,并通过实例说明了常见内存溢出问题的原因和表现形式。这些内容帮助开发者深入理解Java内存管理机制,优化应用程序性能并解决潜在的内存问题。
163 29
JVM简介—1.Java内存区域
|
1月前
|
消息中间件 Java 应用服务中间件
JVM实战—2.JVM内存设置与对象分配流转
本文详细介绍了JVM内存管理的相关知识,包括:JVM内存划分原理、对象分配与流转、线上系统JVM内存设置、JVM参数优化、问题汇总。
JVM实战—2.JVM内存设置与对象分配流转
|
1月前
|
缓存 监控 算法
JVM简介—2.垃圾回收器和内存分配策略
本文介绍了Java垃圾回收机制的多个方面,包括垃圾回收概述、对象存活判断、引用类型介绍、垃圾收集算法、垃圾收集器设计、具体垃圾回收器详情、Stop The World现象、内存分配与回收策略、新生代配置演示、内存泄漏和溢出问题以及JDK提供的相关工具。
JVM简介—2.垃圾回收器和内存分配策略
|
5月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
1012 1
|
2月前
|
存储 算法 Java
JVM: 内存、类与垃圾
分代收集算法将内存分为新生代和老年代,分别使用不同的垃圾回收算法。新生代对象使用复制算法,老年代对象使用标记-清除或标记-整理算法。
38 6