首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    brk与mmap

    前言 glibc的malloc函数在申请大于128K的内存时使用mmap分配内存,mmap会从堆区和栈区中间的部分划分内存,而在申请小于128K的内存时使用brk从堆上划分内存。...2. brk/sbrk brklinux上一个系统调用,而sbrk是一个C库函数 2.1 brk函数原型 int brk(void *addr); 参数 参数 解释 addr 要调整到的内存地址 返回值...sbrk函数原型 void *sbrk(intptr_t increment); 参数 参数 解释 increment 增加的内存大小 返回值 返回增加之后的program break内存地址 2.3 brk...的原理 brk实际是通过改变program break来实现的,这个program break可以理解为“堆顶指针”,意味着程序堆内存使用到了该位置。...总结 方式 内存碎片 适用场景 brk 多,因为不可释放 申请小内存 mmap 无,因为可以直接释放 申请大内存,如果用来申请小内存的话就会创建非常多的vm_area_struct结构体,不划算 5.

    7110

    Linux 内核 内存管理】Linux 内核堆内存管理 ② ( 动态分配堆内存方式 | brk 系统调用 | mmap 系统调用 | brk 系统调用源码介绍 )

    文章目录 一、Linux 系统 动态分配堆内存 方式 二、brk 系统调用 动态分配堆内存 一、Linux 系统 动态分配堆内存 方式 ---- Linux 系统中 , 提供了 2 种方式 进行 "...系统调用 : 向 Linux 操作系统 申请 " 虚拟地址空间 " 内存 , 并且将某个文件 " 映射 “ 到该申请的内存中 ; 如果 不需要映射文件 到该空间中 , 则该空间就是 ” 匿名空间 "..., 可作为 " 堆内存 " 使用 ; 二、brk 系统调用 动态分配堆内存 ---- " brk 系统调用 “ 可以指定 ” 堆内存 “ 在 ” 虚拟内存空间 “ 的 ” 结束地址 " ; 如果要 "...扩张 " 堆内存 , 可以将 结束地址 " 大于当前值 " , 如果要 " 收缩 " 堆内存 , 可以将 结束地址 " 小于当前值 " ; brk 系统调用 源码在 Linux 源码中的 linux-5.6.18...\mm\mmap.c#187 源码中定义 ; SYSCALL_DEFINE1(brk, unsigned long, brk) { unsigned long retval; unsigned long

    5.1K20

    Linux 内核 内存管理】Linux 内核堆内存管理 ① ( 堆内存管理 | 内存描述符 mm_struct 结构体 | mm_struct 结构体中的 start_brkbrk 成员 )

    文章目录 一、堆内存管理 二、内存描述符 mm_struct 结构体 三、mm_struct 结构体中的 start_brkbrk 成员 一、堆内存管理 ---- Linux 操作系统中的 " 堆内存...结构体 ---- mm_struct 结构体 定义在 Linux 内核源码 include\linux\mm_types.h#375 源码中 ; mm_struct 结构体 源码 : struct mm_struct...-5.6.18\include\linux\mm_types.h#375 三、mm_struct 结构体中的 start_brkbrk 成员 ---- mm_struct 结构体中的 start_brk...、brk 成员 , 分别是 " 堆内存 " 在 " 虚拟地址空间 " 的 开始 和 结束 地址 , 其定义在 Linux 内核源码的 linux-5.6.18\include\linux\mm_types.h...#456 源码中 ; unsigned long start_brk, brk, start_stack; 源码路径 : linux-5.6.18\include\linux\mm_types.h

    90031

    Linux 内核 内存管理】内存管理架构 ② ( 用户空间内存管理 | malloc | ptmalloc | 内核空间内存管理 | sys_brk | sys_mmap | sys_munmap)

    文章目录 一、用户空间内存管理 ( malloc / free / ptmalloc / jemalloc / tcmalloc ) 二、内核空间内存管理 1、内核内存管理系统调用 ( sys_brk...glibc 函数库 ( GNU 发布的 libc 库 ) 的 " 内存分配器 " , 由 ptmalloc 函数提供 内存操作接口 ; glibc 库提供的 ptmalloc 函数 的原理是 , 调用 Linux...---- 1、内核内存管理系统调用 ( sys_brk | sys_mmap | sys_munmap ) 在 " 内核空间 " 中 , 调用 Linux 内核中的 sys_brk / sys_mmap...、sys_mmap 系统调用 可参考 【Linux 内核 内存管理】Linux 内核堆内存管理 ② ( 动态分配堆内存方式 | brk 系统调用 | mmap 系统调用 | brk 系统调用源码介绍 )...Linux 操作系统 申请 " 虚拟地址空间 " 内存 , 并且将某个文件 " 映射 “ 到该申请的内存中 ; 如果 不需要映射文件 到该空间中 , 则该空间就是 ” 匿名空间 " , 可作为 " 堆内存

    97110

    一文读懂 Linux 内存分配全过程

    所以,本文主要分析在 Linux 内核中对堆内存分配的实现过程。...本文使用 Linux 2.6.32 版本代码 内存分区对象 在《你真的理解内存分配》一文中介绍过,Linux 会把进程虚拟内存空间划分为多个分区,在 Linux 内核中使用 vm_area_struct...do_anonymous_page 函数的实现比较有趣,它会根据 缺页异常 是由读操作还是写操作导致的,分为两个不同的处理逻辑,如下: 如果是读操作导致的,那么将会使用 零页 进行映射(零页 是 Linux...总结 本文主要介绍了 Linux 内存分配的整个过程,当然只是介绍从堆空间分配的内存的过程。...Linux 分配内存的方式还有很多,比如 mmap、HugePages 等,有兴趣的可以查阅相关的资料和书籍。 如果有问题,可以加我微信一起探讨:JaydenSongLie。

    1.6K41

    Linux 内核 内存管理】内存管理系统调用 ② ( mmap 创建内存映射 | mmap 创建内存映射 与 malloc 申请内存对比 | mmap 创建内存映射 与 普通文件操作对比 )

    文章目录 一、mmap 创建内存映射 与 malloc 申请内存对比 1、malloc 函数原型 2、malloc 申请动态内存过程 3、malloc 使用的系统调用判定 ( brk | mmap )...” 系统调用 " 函数 ; 系统调用接口 是 用户层的 malloc 函数 与 内核层的 vmalloc 函数之间的 桥梁 ; ③ 内核层调用 : 内核与用户层接口 的 内存管理函数 调用 " Linux...内核 " 中的 kmalloc vmalloc 函数 ; 参考 【Linux 内核 内存管理】内存管理架构 ④ ( 内存分配系统调用过程 | 用户层 malloc free | 系统调用层 brk mmap...库 的 ptmalloc " 内存分配器 " 会使用 brk 系统调用 , 向 Linux 内核申请内存 ; 使用 mmap 系统调用 : 如果 应用程序 申请的内存大小 大于等于 划分阈值 , glibc...库 的 ptmalloc " 内存分配器 " 会使用 mmap 系统调用 , 向 Linux 内核申请内存 ; 4、mmap 创建内存映射 mmap 可以直接向 Linux 内核申请 " 虚拟内存 "

    6.2K20

    Linux 内核 内存管理】虚拟地址空间布局架构 ④ ( 内存描述符 mm_struct 结构体成员分析 | hiwater_rss | start_code | start_brk )

    2、hiwater_vm 成员 3、total_vm 成员 4、locked_vm 成员 5、start_code、end_code、 start_data、 end_data 成员 6、start_brk...、 brk、 start_stack 成员 7、arg_start、 arg_end、env_start、 env_end 成员 8、context 成员 一、mm_struct 结构体成员分析 ---...- mm_struct 结构体 在 Linux 源码 linux-4.12\include\linux\mm_types.h#359 位置 ; 参考 【Linux 内核 内存管理】虚拟地址空间布局架构...、 brk、 start_stack 成员 start_brk 是 " 堆内存 " 的 起始地址 , brk 是 " 堆内存 " 的 终止地址 , start_stack 是 " 栈内存 " 的 起始地址...; unsigned long start_brk, brk, start_stack; 7、arg_start、 arg_end、env_start、 env_end 成员 arg_start,

    40810

    Linux 内核 内存管理】内存管理架构 ④ ( 内存分配系统调用过程 | 用户层 malloc free | 系统调用层 brk mmap | 内核层 kmalloc | 内存管理流程 )

    这些函数就是 ” 系统调用 " 函数 ; 系统调用接口 是 用户层的 malloc 函数 与 内核层的 vmalloc 函数之间的 桥梁 ; ③ 内核层调用 : 内核与用户层接口 的 内存管理函数 调用 " Linux...函数用于回收内存 ; 可参考 【Linux 内核 内存管理】Linux 内核堆内存管理 ② ( 动态分配堆内存方式 | brk 系统调用 | mmap 系统调用 | brk 系统调用源码介绍 ) 博客..., 了解 brk 和 mmap 系统调用 ; brk 系统调用 : 该方式本质是 设置 " 进程数据段 “ 的 结束地址 , 将该 ” 结束地址 " 向 高或低 移动 , 实现堆内存的 扩张或收缩...; mmap 系统调用 : 向 Linux 操作系统 申请 " 虚拟地址空间 " 内存 , 并且将某个文件 " 映射 “ 到该申请的内存中 ; 如果 不需要映射文件 到该空间中 , 则该空间就是...” 匿名空间 " , 可作为 " 堆内存 " 使用 ; ③ 内核层 ( 内核空间 ) 内存管理 : 在 Linux 内核中 , 通过 kmalloc vmalloc __get_free_pages

    70310

    Linux虚拟内存管理

    Linux的内存管理分为 虚拟内存管理 和 物理内存管理,本文主要介绍 虚拟内存管理 的原理和实现。在介绍 虚拟内存管理 前,首先介绍一下 x86 CPU 内存寻址的具体过程。...由于Linux把代码段和数据段的基地址都设置为0,所以逻辑地址中的偏移量就等价于线性地址。所以这里就不介绍分段机制了,有兴趣可以查阅相关的文章或者书籍。...由于Linux主要使用分页机制,所以下面重点介绍一下分页机制的原理。...虚拟内存地址管理 应用程序使用 malloc() 函数向Linux内核申请内存时,Linux内核会返回可用的虚拟内存地址给应用程序。...为了加速查找虚拟内存区,Linux内核还为 vm_area_struct 结构构建了一个 AVL树(新版本为红黑树),有兴趣的可以查阅源码或相关资料。

    4K30

    glibc内存管理那些事儿

    Linux内存空间简介 32位Linux平台下进程虚拟地址空间分布如下图: 进程虚拟地址空间分布 图中,0xC0000000开始的最高1G空间是内核地址空间,剩下3G空间是用户态空间。...---- Linux提供了如下几个系统调用,用于内存分配: brk()/sbrk() // 通过移动Heap堆顶指针brk,达到增加内存目的 mmap()/munmap() // 通过文件影射的方式,把文件映射到...那么,既然brk、mmap提供了内存分配的功能,直接使用brk、mmap进行内存管理不是更简单吗,为什么需要glibc呢?...如下图: arena链表 main arena和普通arena的区别 main_arena是为一个使用brk指针的arena,由于brk是堆顶指针,一个进程中只可能有一个,因此普通arena无法使用brk...---- 参考文章 Linux 堆内存管理深入分析 深入剖析glibc内存管理实现及潜在问题 十问Linux虚拟内存管理(glibc)

    3K81

    你真的理解内存分配吗?

    内核空间:存放 Linux 内核代码和数据。 三、brk指针 由此可知,通过 malloc 函数申请的内存地址是由 堆空间 分配的(其实还有可能从 mmap 区分配,这种情况暂时忽略)。...在内核中,使用一个名为 brk 的指针来表示进程的 堆空间 的顶部,如 图4 所示: ? 所以,通过移动 brk 指针就可以达到申请(向上移动)和释放(向下移动)堆空间的内存。...事实上,malloc 函数就是通过移动 brk 指针来实现申请和释放内存的,Linux 提供了一个名为 brk() 的系统调用来移动 brk 指针。...Linux 内核会对 缺页异常 进行修复,修复过程如下: 获取触发 缺页异常 的虚拟内存地址(读写哪个虚拟内存地址导致的)。...查看此虚拟内存地址是否被申请(是否在 brk 指针内),如果不在 brk 指针内,将会导致 Segmention Fault 错误(也就是常见的coredump),进程将会异常退出。

    1.2K50

    Linux进程的内存管理之malloc和mmap

    malloc 在linux标准libc库种,malloc函数的实现会根据分配内存的size来决定使用哪个分配函数,当size小于等于128KB时,调用brk分配;当size大于128KB时,调用mmap...brk 堆内存是由低地址向高地址方向增长。分配内存时,将heap段的最高地址指针mm->brk往高地址扩展。释放内存时,把mm->brk向低地址收缩。 ?...//都需要页对齐,方便映射,mm->brk可以理解为end_brk,即当前进程堆的末尾 newbrk = PAGE_ALIGN(brk); oldbrk = PAGE_ALIGN(mm->brk);...if (oldbrk == newbrk) goto set_brk; /* Always allow shrinking brk. */ if (brk brk) {...: //设置这次请求的brk到进程描述符mm->brk中 mm->brk = brk; populate = newbrk > oldbrk && (mm->def_flags & VM_LOCKED

    5K11

    神秘!申请内存时底层发生了什么?

    标准库 虽然我们可以通过系统让操作系统替我们完成一些特定任务,但这些系统调用都是和操作系统强相关的,Linux和Windows的系统调用就完全不同。...如果你直接使用系统调用的话,那么Linux版本的程序就没有办法在Windows上运行,因此我们需要某种标准,该标准对程序员屏蔽底层差异,这样程序员写的程序就无需修改的在不同操作系统上运行了。...这就是为什么在C语言下同样的open函数既能在Linux下打开文件也能在Windows下打开文件的原因。 说了这么多,这和malloc又有什么关系呢?...原来malloc内存不足时要向操作系统申请内存,操作系统才是真大佬,malloc不过是小弟,对每个进程,操作系统(类Unix系统)都维护了一个叫做brk的变量,brk发音break,这个brk指向了堆区的顶部...(sbrk、mmap也可以)实现的,注意,brk是操作系统的一部分,因此当brk开始执行时,此时就进入内核态了。

    67510

    ELF文件的加载过程(load_elf_binary函数详解)--Linux进程的管理与调度(十三)

    因此,GNU把对于动态链接ELF映像的支持作了分工: 把ELF映像的装入/启动入在Linux内核中;而把动态链接的实现放在用户空间(glibc),并为此提供一个称为”解释器”(ld-linux.so.2...Linux可执行文件类型的注册机制 在说明ELF文件的加载过程以前,我们先回答一个问题,就是: 为什么Linux可以运行ELF文件?.../binfmts.h中 linux支持其他不同格式的可执行程序, 在这种方式下, linux能运行其他操作系统所编译的程序, 如MS-DOS程序, 活BSD Unix的COFF可执行格式, 因此linux...调整bss段的大小 */ retval = set_brk(elf_bss, elf_brk); if (retval) goto out_free_dentry;...= current->mm->start_brk = arch_randomize_brk(current->mm); #ifdef compat_brk_randomized

    7.9K51
    领券