Linux内核有什么之内存管理子系统有什么第二回 —— 单刀直入

2023-11-08 16:01

本文主要是介绍Linux内核有什么之内存管理子系统有什么第二回 —— 单刀直入,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接前一篇文章:Linux内核有什么之内存管理子系统有什么第一回 —— 引言

一、单刀直入 —— 一切从malloc开始

想必大家都使用过malloc(),malloc的全称是memory allocation,中文叫做动态内存分配。其用于申请一块连续的指定大小的内存块区域以void *类型返回分配的内存区域地址。

一般的工程师尤其是上层应用工程师知道怎么用这个函数就可以了,如果再能知道它是从堆(heap)中分配,并且能够注意通过free()释放内存从而避免内存泄漏,就算是比较优秀的工程师了。但那是对于应用工程师而言的,对于底层内核工程师,要求远不止于此。我们要知道malloc()的底层机制,具体是怎样由上到下、由应用到内核的,在内核中都做了哪些工作,最终又是如何返回给应用的。

先来看一下malloc的定义。在Linux终端下通过man malloc查看其说明,如下所示:

名称

malloc

原型

#include <stdlib.h>

void *malloc(size_t size);

说明

malloc()函数分配size个字节,并返回一个指向已分配内存的指针。此分配到的内存并未初始化。如果大小为0,那么malloc()返回NULL,或者返回一个唯一的指针值,该值稍后可以成功传递给free()。

返回值

malloc()函数返回一个指向已分配内存的指针,该指针适合任何内置类型。出现错误时,这些函数返回NULL。成功调用malloc()且大小为零,也可能返回NULL。

默认情况下,Linux遵循乐观的内存分配策略。这意味着当mallo()返回非NULL时,不能保证内存真的可用。如果系统内存不足,一个或多个进程将被OOM杀手杀死。有关更多信息,请参阅proc(5)中/proc/sys/vm/overcommit_memory和/proc/sys/vm/oom_adj的描述,以及Linux内核源文件Documentation/vm/overcommit-accounting.rst。

通常,malloc()从堆中分配内存,并根据需要使用sbrk(2)调整堆的大小;当分配大于MMAP_THRESHOLD字节的内存块时,glibc malloc()实现使用mmap(2)将内存分配为私有匿名映射。MMAP_THRESHOLD默认为128kB,但可以使用mallopt(3)进行调整。

在Linux内核4.7之前,使用mmap(2)执行的分配不受RLIMIT_DATA资源限制的影响;自Linux内核 4.7以来,对于使用mmap(2)执行的分配,也强制执行了此限制。

为了避免多线程应用程序中的损坏,在内部使用互斥锁来保护这些函数所使用的内存管理数据结构。在线程同时分配和释放内存的多线程应用程序中,可能存在对这些互斥对象的争用。为了在多线程应用程序中可伸缩地处理内存分配,如果检测到互斥争用,glibc会创建额外的内存分配区域。每个arena都是一个大的内存区域,由系统内部分配(使用brk(2)或mmap(2)),并使用自己的互斥对象进行管理。

从上边man中对于malloc()的说明可以看到,通过malloc()申请一个堆内的空间,底层要么执行brk,要么执行mmap。

brk是一个系统调用,其入口函数是sys_brk;mmap也是一个系统调用,其入口是sys_mmap。

下一回开始对于这两个系统调用进行深入解析。

这篇关于Linux内核有什么之内存管理子系统有什么第二回 —— 单刀直入的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370955

相关文章

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级