ASAN 极简原理

  1. 物理内存有限,虚拟内存无限。
  2. ASAN 接管了应用程序的 malloc 流程
  3. 每次分配内存,一定使用全新的虚拟地址,并且在地址两端加页保护

OVER

要点:因为虚拟内存资源是“无限”的,所以可以大量浪费。浪费体现在两个方面:

  • 分配过的地址空间,即使 free 过了,也不会再次分配给用户。用户感受到的就是内存分配器每次分配出来的内存地址总是比上一次的高。
    • 已经 free 过的内存区域这里称为 Dead Zone
  • 每次分配一段内存时,总会在两端预留一个页面,并且将这两个页面做读写保护。
    • 两端预留的页面称为 Red Zone
  • RedZone
  • RedZone2

在这个机制的基础上,ASAN 只需要跟踪好每次内存分配的堆栈,就能在出问题的时候准确报告出出问题点。能探测到的内存问题:

  • 访问已经 free 过的内存,触发 Dead Zone 报警
  • 内存访问越界,触发 Red Zone 报警
  • 部分野指针问题,触发 Dead Zone / Red Zone 报警

什么问题 ASAN 不能解决?

  • 部分野指针问题(正好写到了还没有 “Dead” 的内存区域,不会触发任何报警)
  • 8
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Asan(Address Sanitizer)是一种用于检测内存访问错误的工具。它通过在程序运行时在内存中插入虚拟的“检测点”来工作。当程序访问未分配或已释放的内存区域时,Asan会在检测到错误时报告错误并终止程序的执行。 Asan通常用于发现未经处理的内存错误,例如缓冲区溢出、越界访问、使用已释放的内存、重复释放内存等。通过使用Asan,开发人员可以更快地发现和修复这些常见的内存问题,并且还可以在生产环境中使用Asan来检测未知的内存问题。 ### 回答2: Asan(AddressSanitizer)是一种用于检测内存错误的工具,由Google开发。它的原理是在编译阶段对程序进行修改,添加额外的代码来检测内存相关的错误。 Asan主要通过两种方式来检测内存错误:利用内存隔离来检测对未分配的内存的读写,以及在堆栈上分配额外的元数据来检测堆栈缓冲区溢出错误。 对于对未分配的内存的读写,Asan会在内存分配函数中添加代码,用来标记已分配的内存空间,将其与未分配的内存区域隔离开。当程序尝试读取或写入未分配的内存时,Asan会检测到这个错误并立即终止程序运行,同时输出错误信息,帮助开发者定位错误的源头。 对于堆栈缓冲区溢出错误,Asan会在编译时对每个堆栈帧分配额外的元数据。在程序执行过程中,Asan会通过检查这些元数据来检测是否发生了堆栈缓冲区溢出。当发生溢出错误时,Asan会立即终止程序运行,并输出错误信息。 此外,Asan还可以检测使用已释放内存、使用未初始化内存、内存泄漏等其他常见的内存错误。它的实现方式包括在编译时插入检测函数、运行时检查和记录等。 总之,Asan通过修改源程序、添加额外的代码和元数据,来检测并报告内存相关的错误,提供可靠的工具用于程序员进行调试和修复。它在现代软件开发中起到了至关重要的作用,帮助开发者提高程序的稳定性和安全性。 ### 回答3: Asan是一种内存错误检测工具,其原理是通过在程序运行过程中进行动态插桩,对内存分配和访问进行监测和跟踪,以检测潜在的内存错误。 具体来说,Asan通过以下方式实现内存错误的检测: 1. 内存分配:Asan在堆、栈、全局变量等不同的内存区域进行分配时,会在分配的内存块前后添加额外的红区或蓝区,并在每个分配块的元数据中记录其大小。红区和蓝区分别是未分配和已分配内存之间的保护区域。 2. 内存访问:当程序对内存进行读取或写入操作时,Asan会在内存块前后的红区、蓝区检查访问的合法性。如果发现非法访问,例如越界访问数组或释放已经释放的内存,Asan会直接报告相关错误。 3. 内存释放:当程序释放内存时,Asan会检查该内存块是否已经被释放,如果已经被释放或不存在,将报告错误。同时,Asan还会进行内存泄漏检测,如果程序未释放分配的内存块,Asan将会提示有内存泄漏的存在。 4. 错误报告:当Asan检测到内存错误时,会在程序崩溃时提供详细的错误报告。报告包含错误类型、错误发生的位置以及错误堆栈信息,可供开发者进行调试和修复。 总的来说,Asan通过在内存分配和访问以及内存释放过程中进行监测和验证,及时发现和报告内存错误,帮助开发者提高程序的稳定性和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值