GCC 4.8及以上支持内存非法访问检查
来源:互联网 发布:淘宝客服售前必备技巧 编辑:程序博客网 时间:2024/06/07 12:08
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> ./nullpointASAN: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行存在指针错误。
另外还有一个-fsanitize=leak东东,可以检测内存泄露的哦~
程序结束会打印出关于泄露的log
以上两个选项可以同时开
ps:使用这个会导致执行变慢一些,影响不是很大,但是还是建议程序测试期使用。
- GCC 4.8及以上支持内存非法访问检查
- 【Linux开发】GCC 4.8及以上支持内存非法访问检查
- 【Linux开发】GCC 4.8及以上支持内存非法访问检查
- illegal memory access(非法内存访问)
- 请检查是否存在数组越界非法访问等情况
- ArcEngine 10.0以上 许可检查及初始化
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- Windows2008 32位开启服务器PAE大内存支持及SQLServer使用3G以上内存教程
- linux下安装或升级GCC 4.8以上版本(包括),以支持C++11
- 构建带内存错误检查的gcc
- 检查非法字符
- 内核非法MAC检查
- 一种内存非法访问【C++警示录一】
- Error:Dll调用问题,0X000005地址内存非法访问
- 实例介绍利用valgrind定位内存非法访问问题
- Tomcat8及以上配置Manager访问权限
- vs2005及以上检测测内存泄漏
- Linux_入门之设备的访问及软件安装
- 获取当前系统的换行符
- C#基础认知笔记
- Microsoft WNS推送服务 , Server&Client Code
- leetcode 219. Contains Duplicate II
- GCC 4.8及以上支持内存非法访问检查
- 数据库---多表查询、关联查询、不同情况下数据库表设计
- 2017/7/28 开博
- MD5算法的实现详解
- m、p的一些事项
- Android内存泄漏分析总结
- (二) u-boot 配置、编译过程分析
- 快节奏下的老公抱现象
- 第一章 maven简介