用 gdb 运行我的程序我得到这个:
fem.o: malloc.c:3096: sYSMALLOc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1) - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct malloc_chunk, fd_nextsize))+((2 * (sizeof(size_t))) - 1)) & ~((2 * (sizeof(size_t))) - 1))) && ((old_top)->size & 0x1) && ((unsigned long)old_end & pagemask) == 0)' failed.
Program received signal SIGABRT, Aborted. 0xb7fe1424 in __kernel_vsyscall ()
我发现这个错误出现在这段代码之后:
problem->y0 = (double *)calloc(n_tot, sizeof(double));
问题是一个具有双*y0 作为成员的结构。
之前在函数中,我是这样做的
problem = (fem_problem *)calloc(1, sizeof(fem_problem));
而且我没有收到任何错误,也没有问题 == NULL。
一些建议?
添加:
我已经检查了n_tot的内容,它有正确的数字
最佳答案
该断言告诉您堆内部数据结构已损坏,可能是由于您在某个时候在已分配 block 的边界之外进行写入。尝试使用 valgrind 运行看看它是否能告诉您哪里出错了。
关于c - malloc/calloc 调用上出现奇怪的 SIGABORT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5540672/