【Linux开发】GCC 4.8及以上支持内存非法访问检查
来源:互联网 发布:php 积分兑换 编辑:程序博客网 时间:2024/06/03 21:37
gcc4.8及以上版本支持地址越界,野指针检查,只需要在编译时使用-fsanitize=address选项即可,当运行程序时如果访问非本程序申请的地址就会报错。
root@localhost:/home/ngos/practice> vi nullpoint.c
1 #include "stdio.h"
2
3 int main(int argc , char **argv)
4 {
5 int *p = NULL;
6 *p = 10;
7 printf("%d",*p);
8
9 return 0;
10 }
root@localhost:/home/ngos/practice> gcc -g -fsanitize=address -o nullpoint nullpoint.c
root@localhost:/home/ngos/practice> ls
nullpoint nullpoint.c
root@localhost:/home/ngos/practice> ./nullpoint
ASAN:SIGSEGV
=================================================================
==3696==ERROR: AddressSanitizer: SEGV on unknown address 0x000000000000 (pc 0x00000040085a sp 0x7fff603db8b0 bp 0x7fff603db8d0 T0)
#0 0x400859 in main /home/ngos/practice/nullpoint.c:6
#1 0x7faa9bd19b5d in __libc_start_main (/lib64/libc.so.6+0x1eb5d)
#2 0x4006c8 (/home/ngos/practice/nullpoint+0x4006c8)
AddressSanitizer can not provide additional info.
SUMMARY: AddressSanitizer: SEGV /home/ngos/practice/nullpoint.c:6 main
==3696==ABORTING
由上面的错误提示信息可以看到第6行存在指针错误。
- 【Linux开发】GCC 4.8及以上支持内存非法访问检查
- 【Linux开发】GCC 4.8及以上支持内存非法访问检查
- GCC 4.8及以上支持内存非法访问检查
- linux下安装或升级GCC 4.8以上版本(包括),以支持C++11
- 如何使32位Linux支持4G以上内存
- linux内存检查及本身程序解决方案!!!
- illegal memory access(非法内存访问)
- Linux下数组非法访问导致内存破坏 —— 引发segmentation fault的原因
- Linux环境定位C程序内存泄露以及非法访问的方法
- 请检查是否存在数组越界非法访问等情况
- ArcEngine 10.0以上 许可检查及初始化
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- iOS开发——设置支持的iOS设备(512m内存以上设备)
- iOS开发——设置支持的iOS设备(512m内存以上设备)
- linux 检查内存情况
- 内存检查 linux
- TCP为什么是三次握手不是两次四次呢?
- ByteBuffer 缓冲器(一)
- Linux中安装MongoDB
- Delphi泛型应用示例之二:通用数据池
- 信息图:如何成为一名数据科学家?
- 【Linux开发】GCC 4.8及以上支持内存非法访问检查
- Java概述(一)
- 数据类型转换图
- submit 控制
- 想学JS的原型和闭包吗?COME ON(2)
- Javascript实现的飘雪效果
- Xcode 的正确打开方式——Debugging
- ie8对于onmessage 事件的监听和取消
- 可将ppt转换成pdf格式的转换器