2

gdb でプログラムを実行すると、次のようになります。

fem.o: malloc.c:3096: sYSMALLOC: アサーション `(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));

問題は、メンバーとして 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 に答える