为什么memset(szBuf, 0, sizeof(szBuf));会莫名其妙core dump?

来源:互联网 发布:控制网络与现场总线 编辑:程序博客网 时间:2024/05/22 13:58

       最近写了点代码, 结果程序必然core dump, 用gdb分析了, 定位在fun函数的这里:memset(szBuf, 0, sizeof(szBuf));    其中szBuf的定义是char szBuf[102400] = {0};

       真是让我百思不得其解, 这里绝对没有越界啊。 而且, 在别的地方调用fun函数不会出问题啊。

       实在定位不出来, 请教了一下相关同学, 原来是: 在那个“特别体系结构”中, 有栈限制, 而我调用了fun函数。 解决方法是: 加大栈限制。

       原来如此, 如果让我单独定位, 这个问题是不太容易搞出来的。




  ;

0 0