valgrind问题

程序发现段错误了,通过栈打印出来的信息来看,段错误是发生在malloc的时候,应该是内存越界了吧。
不用valgrind运行又必现的段错误,一用valgrind来跑却又不出现了。

大家见过这种情况吗? 这是为什么? 对于malloc段错误,有没有更好的方法来进行定位?

作者: gohome520   发布时间: 2011-04-29

malloc段错误,很可能是LZ传的申请内存值的大小有问题
建议:
  char *Ptr = NULL; 
  Ptr = (char *)malloc(** sizeof(char)); 
  if (NULL == Ptr) 
  { 
  //标记出错位置
  。。。。
  } 
 

作者: yfkiss   发布时间: 2011-04-30

引用 1 楼 yfkiss 的回复:

malloc段错误,很可能是LZ传的申请内存值的大小有问题
建议:
char *Ptr = NULL;
Ptr = (char *)malloc(** sizeof(char));
if (NULL == Ptr)
{
//标记出错位置
。。。。
}
……

谢谢你的回复,但是如果传入的内存值有问题只是内存申请失败,而不会导致段错误的。
从我捕获的段错信号得到的信息来看,si_code值为1,也就是SEGV_MAPERR,这种情况,基本肯定是内存越界操作了。
只是不明白的是,用valgrind来跑却又没出现问题。

作者: gohome520   发布时间: 2011-04-30