内存越界的现象及调试方法

原创 2007年09月21日 12:41:00

内存越界的现象及调试方法

   作者:lanhai 来源:www.dx001.com 转载请保留

遇到了好几回这样的事的,在这里总结一下经验,期待您的丰富

现象:
 1 程序出现异常 异常的现象有很多,如:代码突然跑到不相干的地方去执行,访问异常,正常的变量操作也报错...
     原因:代码段紊乱,this指针被改变,指针指向的数据被改变
 2 程序按逻辑执行,但数据错误  如:变量内容突然消失
     原因:变量所在空间被其它操作误删除等
 3 其它莫名其妙的错误
原因:
 越界的基本比较原因,如
         1 写越界:      向10个字节的数组写入了20个字节;内存操作越界,如char szText[10];memset(szText,0,30);
         2 错误的函数调用:   sprintf等fmt中的预定义和实际输入的变量数不一致,如sprintf(szData,"Name:%d title:%s",1)

         3 错误的调用方式:  用stdcall 的函数指针 调用pascall的函数

 
检查方法: 
 1 BoundChecker进行调试,BoundChecker在代码编译时加入了大量的附加处理,其中包括内存堆栈检测等,其实ms的debug模式也做了许多的类似操作,但debug模式下的一些代码行为,如初始化变量,和Release下的代码执行不同,所以用debug调试不是完美的方式
 2 类内部出现莫名其妙的错误时,查看 this 指针是否变化,方法是在调试的 "查看" 窗口 输入:this ;必要的时候进行手手工检查
 3 在调试的 "查看" 窗口 输入:@err,hr 看全局错误变量的内容,也许有提示
 4 注释掉部分代码,看是否错误还出现,注释的最佳方式是:二分法

  5 查看程序异常处的反汇编代码,分析原因
  

内存越界分析与解决办法——20110707

1. 原理分析经常有些新C++程序员问:C++的类的成员个数是不是有限制,为什么我加一个变量后程序就死了?或者说:是不是成员变量的顺序很重要,为什么我两个成员变量顺序换一换程序就不行了?凡此种种之怪现...
  • jaymade
  • jaymade
  • 2011年07月07日 09:45
  • 3286

内存越界问题查找方法

1.使用对比的方法,和没有故障的版本对,对比可能越界的内存 2.如果定位到了越界的变量或者数组,尝试复现,然后查看内存,是否有变化,如果有确定越界的内容是否和猜想的一致。 3.查看变量符号的内存位...
  • kakaka2011
  • kakaka2011
  • 2016年03月19日 16:33
  • 535

嵌入式linux内存越界定位和解决

碰到一个内存越界,设备起来后不久报错并当机,串口打印为*** glibc detected *** ./server: double free or corruption (!prev): 0x08a...
  • meejoy
  • meejoy
  • 2014年12月04日 20:17
  • 1188

内存越界的一种定位方法

#include #include #include void fn(char *str) { memset(str, 0, 64); return; } int main(...
  • fengyifan5
  • fengyifan5
  • 2013年05月16日 16:13
  • 1077

Linux内存越界检测方法——valgrind

 Linux内存越界检测方法——valgrind 一.Valgrind 1.下载安装 下载地址:http://valgrind.org/downloads/current.html...
  • wutong_login
  • wutong_login
  • 2015年01月12日 09:09
  • 6639

内存越界排查方法

只想说此方法简单粗暴有疗效! #ifdef _DEBUG #  define _CRTDBG_MAP_ALLOC #  define _CRTDBG_MAP_ALLOC_NEW #  ...
  • jize00
  • jize00
  • 2014年12月12日 15:14
  • 622

C基础 内存越界和内存监测的简单处理

前言  -  内存越界处理 我们先看设计图. 内存越界检查原理如下 上面原理是不是很简单. 而这恰恰是最通用的做法. 美的东西不负责.  美很重要. 那我们按照上面设计思路....
  • whChina
  • whChina
  • 2016年05月18日 22:09
  • 2197

检测内存越界错误的工具---pageheap和gflag

我推荐使用PageHeap.Exe和Gflags.Exe,主要的原因还是因为当有人问内存越界的错误如何查出来的时候,国外的朋友经常会推荐这两个工具(highly recommend)。我用过之后,也觉...
  • shanzhizi
  • shanzhizi
  • 2012年08月08日 09:21
  • 3929

如何调试malloc(堆越界)问题

如何调试malloc(堆越界)问题 [DESCRIPTION] 有一类NE比较特殊,就是堆引起的异常(调用malloc申请的内存后使用不当引起的异常): 1. 申请后多次释放 (doub...
  • sandform
  • sandform
  • 2016年05月26日 16:24
  • 1929

使用 electric-fence 调试内存越界

使用 electric-fence 调试内存越界 2012-12-14 16:40:53| 分类: linux使用 |举报|字号 订阅 在嵌入式上开发底层软件经常会遇见莫名其妙的问题,尤其是...
  • xiaocao9903
  • xiaocao9903
  • 2014年09月11日 10:41
  • 1387
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:内存越界的现象及调试方法
举报原因:
原因补充:

(最多只允许输入30个字)