2

用 gdb 运行我的程序我得到了这个:

fem.o: malloc.c:3096: sSYSMALLOc: 断言`(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)' 失败。

程序收到信号 SIGABRT,已中止。__kernel_vsyscall() 中的 0xb7fe1424

我发现这个错误出现在这段代码之后:

problem->y0 = (double *)calloc(n_tot, sizeof(double));

问题是具有双 *y0 作为成员的结构。

以前在函数中,我这样做

problem = (fem_problem *)calloc(1, sizeof(fem_problem));

而且我也没有收到任何错误== NULL。

一些建议?

添加:

我已经检查了 n_tot 的内容,它有正确的数字

4

2 回答 2

8

断言告诉您堆内部数据结构已损坏,可能是由于您在某个时间点超出了已分配块的范围。尝试使用valgrind运行,看看它是否能告诉你哪里出错了。

于 2011-04-04T16:50:03.973 回答
4

可能存在许多问题,例如:

  • 的值n_tot可能是垃圾。

  • 您已经在分配的块之外进行了写入,并且这样做您已经破坏了用于维护堆的数据结构。

于 2011-04-04T15:28:39.490 回答