Linux 内核给每个进程都提供了一个独立的虚拟地址空间,并且这个地址空间是连续的。这样进程就可以很方便地访问内存,更确切地说是访问虚拟内存。

1、什么是虚拟内存

假设某个进程需要100MB的空间,而内存假设是16MB的,如果进程直接使用物理地址,就会因为内存不足而无法运行。

既然进程不是直接访问物理内存,那么进程中涉及的内存地址当然也不是物理内存地址。而是虚拟的内存地址,虚拟的内存地址和物理的内存地址之间保持一种映射关系,这种关系由内存管理单元(MMU)进行管理。

内存管理单元(Memory Management Unit,MMU),将物理内存分割成多个pages,MMU管理进程的虚拟地址空间中的page和物理内存中的page之间的映射关系。

因为是映射,所以随时都可能发生变化,例如某个进程虚拟内存空间中的page1,在不同的时间点,可能出现在物理内存中的不同位置(当发生了页交换时)。

2、什么是 page fault

虚拟地址空间的内部又被分为内核空间和用户空间两部分。并不是所有的虚拟内存都会分配物理内存,只有那些实际使用的虚拟内存才分配物理内存,并且分配后的物理内存,是通过内存映射来管理的。

当进程访问它的虚拟地址空间中的page时,如果这个page目前还不在物理内存中,此时CPU是不能工作的,Linux会产生一个hard page fault中断。系统需要从慢速设备(如磁盘)将对应的数据page读入物理内存,并建立物理内存地址与虚拟地址空间page的映射关系。然后进程才能访问这部分虚拟地址空间的内存。

page fault 又分为三种:minor page fault、major page fault、invalid(segment fault)。

2.1、minor page fault

也称为 soft page fault,指需要访问的内存不在虚拟地址空间,但是在物理内存中,需要MMU建立物理内存和虚拟地址空间的映射关系即可。

当一个进程在调用 malloc 获取虚拟空间地址后,首次访问该地址会发生一次soft page fault。

通常是多个进程访问同一个共享内存中的数据,当某些进程还没有建立起映射关系,访问时也会出现soft page fault。

2.2、major page fault

也称为 hard page fault,指需要访问的内存不在虚拟地址空间,也不在物理内存中,需要从慢速设备载入。

从磁盘 swap in 回到物理内存就是 hard page fault。

  • swap out:当物理内存不够时,把一些物理内存page中的内容写入到磁盘,以腾出一些空闲的page;
  • swap in:当CPU要执行的指令被发现已经swap out到了磁盘中, 这时就需要从磁盘把这些指令再swap in到物理内存中。

注意:swap in 和 swap out 的操作都是比较耗时的。

2.3、invalid(segment fault)

也称为 segment fault,指进程需要访问的内存地址不在它的虚拟地址空间范围内,属于越界访问,内核就会报 segment fault 错误。

造成 segment fault 的原因可能有以下几种:

  • 堆栈溢出;
  • 内存访问越界,如数组下表错误访问越界;使用strcpy/strcat/sprintf/strcmp 等字符串操作函数导致的读写越界,应尽量使用strncpy/strncat/snprintf/strncmp 等函数防止读写越界;
  • 非法指针:野指针,错误的指针转换等;
  • 多线程读写的数据未加锁保护,或使用了线程不安全的函数。

linux 内存越界判断_虚拟内存 和 page fault 的解释相关推荐

  1. linux 内存越界判断_linux 内存越界判断

    printf("aaa\n");这不是在打印a字符吗?,而且,只有段越界才会引起进程的段错误信号,你访问的地址仍然在进程的合法空间范围内,当然空指针这类地址基本不合法.回复 @xx ...

  2. linux 内存越界判断_LINUX 共享内存越界

    shmget的时候,我们能指定共享内存的size,当size越界的时候,会如何呢? 如下: /* * ShareMem.h * *  Created on: 2013-2-25 *      Auth ...

  3. linux 内存不足时候 应该及时回收page cache

    另一起问题是24G内存的系统,空闲内存已经不到50M 1. 确认该系统的版本是64位 # uname -a Linux gxgd-nms-app 2.6.18-194.el5xen #1 SMP Tu ...

  4. 已提交内存过大_虚拟内存别关!?!

    内存是干什么吃的? 计算机程序运行时的临时数据都放置在内存.如果内存过小,应用没有足够的空间放置临时数据,就会导致应用的崩溃.典型的内存不足错误如下: 虚拟内存--它是假的吗? 为了节省购买内存的成本 ...

  5. linux 内存溢出排查_记一次JAVA 线上故障排查完整套路

    JAVA线上故障排查全套路 线上故障主要会包括cpu.磁盘.内存以及网络问题,而大多数故障可能会包含不止一个层面的问题,所以进行排查时候尽量四个方面依次排查一遍.同时例如jstack.jmap等工具也 ...

  6. linux 内存溢出排查_【开发者成长】JAVA 线上故障排查完整套路!

    云栖号资讯:[点击查看更多行业资讯] 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 线上故障主要会包括 CPU.磁盘.内存以及网络问题,而大多数故障可能会包含不止一个层面的问题,所以 ...

  7. linux那些事之page fault(AMD64架构)(user space)(2)

    do_user_addr_fault 用户空间地址处理是page fault主要处理流程,x86 64位系统主要是do_user_addr_fault()函数 该处理部分是x86架构特有部分 即与架构 ...

  8. linux 内存管理 page fault带来的性能问题

    Linux进程如何访问内存 Linux下,进程并不是直接访问物理内存,而是通过内存管理单元(MMU)来访问内存资源. 原因后面会讲到. 为什么需要虚拟内存地址空间 假设某个进程需要4MB的空间,内存假 ...

  9. 嵌入式linux内存使用和性能优化

    这本书有两个关切点:系统内存(用户层)和性能优化. 这本书和Brendan Gregg的<Systems Performance>相比,无论是技术层次还是更高的理论都有较大差距.但是这不影 ...

最新文章

  1. JDK6.0+Eclipse3.2+MyEclipse5.0GA+Tomcat5.0+Win2003搭建J2EE开发平台.
  2. 20155335俞昆 2017-2018-1 《信息安全系统设计》第9周学习总结
  3. 区块链教程Fabric1.0源代码分析Tx(Transaction 交易)一
  4. 华为交换机同步linux时间服务器,华为s5720s系列交换机同步时间
  5. 一些stl格式的点云的显示结果
  6. JAVA正则表达式:Pattern类与Matcher类详解
  7. C++ Primer 5th笔记(chap 19 特殊工具与技术)类成员指针
  8. 计算机二级ms office过关,计算机二级office-计算机二级MS OFFICE过关攻略!附赠练习软件...
  9. 如何编写第一个 ngrx Effect 类
  10. IntelliJ Idea 常用插件
  11. [html] history和hash两种路由方式的最大区别是什么?
  12. SQL Server更新某一列中多个字典码对应内容(sql示例)
  13. 静态链表相关算法学习
  14. 书籍《循环经济之道》-观后感-2021年12月
  15. 记一次ajax交互问题
  16. 简单的python案例_实现的简单python例子
  17. 金融行业文档管理系统的八大创新
  18. Restful 风格
  19. 荐书:「时差党」——出国留学不是一件容易的事
  20. 怒赞!7个下载UI组件包的顶级网站

热门文章

  1. excel条件格式详解
  2. django后端用websocket传输数据
  3. Pytest fixture参数化params
  4. java ArrayList的实现
  5. 【bzoj3343】教主的魔法 (分块 + 二分)
  6. 实例讲解webpack的基本使用第二篇
  7. 下面哪个进制能表述 13*16=244是正确的?)[中国台湾某计算机硬件公司V2010年5月面试题]...
  8. cannot be resolved or is not a field
  9. HDU 4422 The Little Girl who Picks Mushrooms(简单题)
  10. vici 开源asp.net mvc支持asp.net2.0II6.0下部署 实例下载地址