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()`等,用于满足特定场景的需求。

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

目录
相关文章
|
3天前
|
算法 Linux 调度
深入理解Linux内核调度器:从基础到优化####
本文旨在通过剖析Linux操作系统的心脏——内核调度器,为读者揭开其高效管理CPU资源的神秘面纱。不同于传统的摘要概述,本文将直接以一段精简代码片段作为引子,展示一个简化版的任务调度逻辑,随后逐步深入,详细探讨Linux内核调度器的工作原理、关键数据结构、调度算法演变以及性能调优策略,旨在为开发者与系统管理员提供一份实用的技术指南。 ####
18 4
|
4天前
|
缓存 负载均衡 Linux
深入理解Linux内核调度器
本文探讨了Linux操作系统核心组件之一——内核调度器的工作原理和设计哲学。不同于常规的技术文章,本摘要旨在提供一种全新的视角来审视Linux内核的调度机制,通过分析其对系统性能的影响以及在多核处理器环境下的表现,揭示调度器如何平衡公平性和效率。文章进一步讨论了完全公平调度器(CFS)的设计细节,包括它如何处理不同优先级的任务、如何进行负载均衡以及它是如何适应现代多核架构的挑战。此外,本文还简要概述了Linux调度器的未来发展方向,包括对实时任务支持的改进和对异构计算环境的适应性。
21 6
|
5天前
|
缓存 Linux 开发者
Linux内核中的并发控制机制:深入理解与应用####
【10月更文挑战第21天】 本文旨在为读者提供一个全面的指南,探讨Linux操作系统中用于实现多线程和进程间同步的关键技术——并发控制机制。通过剖析互斥锁、自旋锁、读写锁等核心概念及其在实际场景中的应用,本文将帮助开发者更好地理解和运用这些工具来构建高效且稳定的应用程序。 ####
20 5
|
5天前
|
缓存 运维 网络协议
深入Linux内核架构:操作系统的核心奥秘
深入Linux内核架构:操作系统的核心奥秘
22 2
|
网络协议 NoSQL Linux
阿里云 Linux 内核优化实战(sysctl.conf 和 ulimits )
一、sysctl.conf优化Linux系统内核参数的配置文件为 /etc/sysctl.conf 和 /etc/sysctl.d/ 目录。其读取顺序为: /etc/sysctl.d/ 下面的文件按照字母排序;然后读取 /etc/sysctl.conf 。
8597 1
|
5天前
|
缓存 资源调度 安全
深入探索Linux操作系统的心脏——内核配置与优化####
本文作为一篇技术性深度解析文章,旨在引领读者踏上一场揭秘Linux内核配置与优化的奇妙之旅。不同于传统的摘要概述,本文将以实战为导向,直接跳入核心内容,探讨如何通过精细调整内核参数来提升系统性能、增强安全性及实现资源高效利用。从基础概念到高级技巧,逐步揭示那些隐藏在命令行背后的强大功能,为系统管理员和高级用户打开一扇通往极致性能与定制化体验的大门。 --- ###
25 9
|
5天前
|
算法 Unix Linux
深入理解Linux内核调度器:原理与优化
本文探讨了Linux操作系统的心脏——内核调度器(Scheduler)的工作原理,以及如何通过参数调整和代码优化来提高系统性能。不同于常规摘要仅概述内容,本摘要旨在激发读者对Linux内核调度机制深层次运作的兴趣,并简要介绍文章将覆盖的关键话题,如调度算法、实时性增强及节能策略等。
|
8天前
|
机器学习/深度学习 负载均衡 算法
深入探索Linux内核调度机制的优化策略###
本文旨在为读者揭开Linux操作系统中至关重要的一环——CPU调度机制的神秘面纱。通过深入浅出地解析其工作原理,并探讨一系列创新优化策略,本文不仅增强了技术爱好者的理论知识,更为系统管理员和软件开发者提供了实用的性能调优指南,旨在促进系统的高效运行与资源利用最大化。 ###
|
7天前
|
监控 网络协议 算法
Linux内核优化:提升系统性能与稳定性的策略####
本文深入探讨了Linux操作系统内核的优化策略,旨在通过一系列技术手段和最佳实践,显著提升系统的性能、响应速度及稳定性。文章首先概述了Linux内核的核心组件及其在系统中的作用,随后详细阐述了内存管理、进程调度、文件系统优化、网络栈调整及并发控制等关键领域的优化方法。通过实际案例分析,展示了这些优化措施如何有效减少延迟、提高吞吐量,并增强系统的整体健壮性。最终,文章强调了持续监控、定期更新及合理配置对于维持Linux系统长期高效运行的重要性。 ####
|
10天前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###