1

我的程序在 main() 函数之前崩溃。我使用“cerr”确定这一点:

int main(int argc, char **argv)
{
  cerr << " MAAIN " << endl;

来自 gdb 的消息:

   Reading symbols for shared libraries ...........+++............................ done
CA(34652) malloc: *** error for object 0x7fff76694860: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug

Program received signal SIGABRT, Aborted.
0x00007fff88e1782a in __kill ()
(gdb) bt
#0  0x00007fff88e1782a in __kill ()
#1  0x00007fff8c4d2a9c in abort ()
#2  0x00007fff8c53184c in free ()
#3  0x00000001026a1db0 in std::basic_stringbuf<char, std::char_traits<char>, std::allocator<char> >::overflow ()
(gdb) 

我已经检查了“删除”和“免费”功能的代码。所有删除都通过这样的检查完成:

if (x) delete x;

请帮我回答两个问题: 1. 可能的问题是什么?2. 怎么找?(我有一个包含很多文件的大代码和用于编译的 cmake)。

PS 我读过C/C++ 程序有什么方法可以在 main() 之前崩溃吗? 但看着 gdb 按摩我想图书馆还可以。

4

2 回答 2

2

cout不是检查程序崩溃位置的好方法,因为cout不会立即刷新其缓冲区,并且您的程序可能cout在刷新缓冲区之后但之前崩溃。最好检查它cerr而不是cout

在 main 函数之前,会调用全局变量的构造函数。因此,如果您认为它在开始前崩溃,请查看它们。

另一种可能性是在调用主函数之前为主函数中的数组分配内存。如果它们很大。您必须使用new为它们分配内存。

于 2013-08-06T21:22:39.150 回答
1

std::basic_stringbuf<char, std::char_traits<char>...告诉我这std::string是错误的。一种非常可能的情况是,您有一些东西试图“释放”一个字符串,该字符串尚未正确构造或已被不小心使用数组覆盖。

或者你依赖于不同源文件中的一些全局变量,所以你有这样的东西:

 // main.cpp:

 ... 
 extern string str;  // str lives in another .cpp file
 .... 
 myclass x(str);   // Construction using str. 

 // otherfile.cpp
 string str("foobar"); 

在这种情况下,str可能在正在构造的时候x没有被构造,并且字符串是“无效的”。

沿着类似的思路还有很多其他的可能性。

这里的地址:0x7fff76694860在堆栈上。如果它总是相同的值,您可以尝试追踪它的位置。

于 2013-08-06T22:45:19.837 回答