0

クラスコールグリッドがあります。このクラスは、グリッドを格納するための 2 つの 2D char 配列を保持します。クラスには、グリッドのメモリを作成し、グリッドのメモリを解放するための 2 つの関数があります。

Grid.h

private:
char **gridOne;
char **gridTwo;

Grid.cpp

void Grid::allocateGridMem()
{
   _gridOne = new char*[gridRowCount()];
   _gridTwo = new char*[gridRowCount()];

   for(int i =0; i < gridColumnCount(); ++i){
      *(_gridOne + i) = new char[gridColumnCount()];
      *(_gridTwo + i) = new char[gridColumnCount()];
   }
}

void Grid::dealocateGridMem()
{
   if(_gridOne != 0)
   {
      for(int i =0; i < gridRowCount(); ++i){
         delete [] *(_gridOne + i);
      }
      delete [] _gridOne;
      _gridOne = 0;
   }

   if(_gridTwo != 0)
   {
      for(int i =0; i < gridRowCount(); i++){
         delete [] *(_gridTwo + i);
      }
      delete [] _gridTwo;
      _gridTwo = 0;
   }
}

問題は、次のエラーを受け取るメモリの割り当て解除で発生しています。

    *** glibc detected *** ./a.out: double free or corruption (out): 0x088c9318 ***
    ======= Backtrace: =========
    /lib/tls/i686/cmov/libc.so.6(+0x6b591)[0xb756c591]
    /lib/tls/i686/cmov/libc.so.6(+0x6cde8)[0xb756dde8]
    /lib/tls/i686/cmov/libc.so.6(cfree+0x6d)[0xb7570ecd]
    /usr/lib/libstdc++.so.6(_ZdlPv+0x21)[0xb775c741]
    /usr/lib/libstdc++.so.6(_ZdaPv+0x1d)[0xb775c79d]
    ./a.out[0x804a7b9]
    ./a.out[0x8049cb6]
    ./a.out[0x804b8f3]
    ./a.out[0x804c06a]
    ./a.out[0x804b71d]
    ./a.out[0x80498eb]
    /lib/tls/i686/cmov/libc.so.6(__libc_start_main+0xe6)[0xb7517bd6]
    ./a.out[0x8049521]
    ======= Memory map: ========
    08048000-0804f000 r-xp 00000000 08:02 920728     /home/a.out
    0804f000-08050000 r--p 00006000 08:02 920728     /home/a.out
    08050000-08051000 rw-p 00007000 08:02 920728     /home/a.out
    088c7000-088e8000 rw-p 00000000 00:00 0          [heap]
    b7300000-b7321000 rw-p 00000000 00:00 0 
    b7321000-b7400000 ---p 00000000 00:00 0 
    b7500000-b7501000 rw-p 00000000 00:00 0 
    b7501000-b7654000 r-xp 00000000 08:02 19796293   /lib/tls/i686/cmov/libc-2.11.1.so
    b7654000-b7655000 ---p 00153000 08:02 19796293   /lib/tls/i686/cmov/libc-2.11.1.so
    b7655000-b7657000 r--p 00153000 08:02 19796293   /lib/tls/i686/cmov/libc-2.11.1.so
    b7657000-b7658000 rw-p 00155000 08:02 19796293   /lib/tls/i686/cmov/libc-2.11.1.so
    b7658000-b765b000 rw-p 00000000 00:00 0 
    b765b000-b7678000 r-xp 00000000 08:02 19791955   /lib/libgcc_s.so.1
    b7678000-b7679000 r--p 0001c000 08:02 19791955   /lib/libgcc_s.so.1
    b7679000-b767a000 rw-p 0001d000 08:02 19791955   /lib/libgcc_s.so.1
    b767a000-b767b000 rw-p 00000000 00:00 0 
    b767b000-b769f000 r-xp 00000000 08:02 19796301   /lib/tls/i686/cmov/libm-2.11.1.so
    b769f000-b76a0000 r--p 00023000 08:02 19796301   /lib/tls/i686/cmov/libm-2.11.1.so
    b76a0000-b76a1000 rw-p 00024000 08:02 19796301   /lib/tls/i686/cmov/libm-2.11.1.so
    b76a1000-b778a000 r-xp 00000000 08:02 28708531   /usr/lib/libstdc++.so.6.0.13
    b778a000-b778b000 ---p 000e9000 08:02 28708531   /usr/lib/libstdc++.so.6.0.13
    b778b000-b778f000 r--p 000e9000 08:02 28708531   /usr/lib/libstdc++.so.6.0.13
    b778f000-b7790000 rw-p 000ed000 08:02 28708531   /usr/lib/libstdc++.so.6.0.13
    b7790000-b7797000 rw-p 00000000 00:00 0 
    b77a5000-b77a8000 rw-p 00000000 00:00 0 
    b77a8000-b77a9000 r-xp 00000000 00:00 0          [vdso]
    b77a9000-b77c4000 r-xp 00000000 08:02 19791897   /lib/ld-2.11.1.so
    b77c4000-b77c5000 r--p 0001a000 08:02 19791897   /lib/ld-2.11.1.so
    b77c5000-b77c6000 rw-p 0001b000 08:02 19791897   /lib/ld-2.11.1.so
    bf83a000

-bf84f000 rw-p 00000000 00:00 0          [stack]
Aborted

私はすべてのポインターが実行中に他の何かに変更されていないこと、および考えられるすべてのチェックとバランスが儀式で行われていることを確認しました。私はここ数時間髪を引っ張っていますが、まだ何もありません.

ubuntu 10システムでgccでこれを実行しています。

また、この投稿の目的で名前などを変更し、価値があると思われるコードのみを含めたことにも注意してください。

編集:

構文の問題を修正しましたが、元のコードにはこれがあり、すぐに入力しただけで、校正はしていませんでした。

どんな助けでも大歓迎であり、私の本の金の星に値します. 私は非常にgdbの上級ユーザーであり、この問題でこれを使用しましたが、おそらく外部ライブラリの問題であると考えています。誰かがこのようなものを見たことを期待するだけで、メモリとそのスコープに問題は見られません。すべての目的で、このコードは問題ありません。

4

5 に答える 5

3

変化する

for(int i =0; i < gridColumnCount(); ++i){
   _gridOne = new char[gridColumnCount()];
   _gridTwo = new char[gridColumnCount()];
}

for(int i =0; i < gridRowCount(); ++i){
   _gridOne[i] = new char[gridColumnCount()];
   _gridTwo[i] = new char[gridColumnCount()];
}

その上、しないでください

*(array + i)

しかし

array[i]
于 2010-07-22T10:05:49.900 に答える
1

おそらく、のループ内では_gridOne[i]なく、そうすべきです。ただし、このような低レベルの操作は可能な限り避け、代わりに高レベルのコンポーネントを使用してください。_gridOneallocateGridMemboost::numeric::ublas::matrix

于 2010-07-22T10:03:51.307 に答える
1

あなたのそのGridクラスには、コピー コンストラクター代入演算子がありますか? そうしないと、そのようなオブジェクトをコピーすると、このエラーが発生します。

手動のリソース管理をやめて、メモリを管理するGridの周りに薄い 2 次元ラッパーを作成することをお勧めします。std::vector<char>

于 2010-07-22T10:32:53.680 に答える
0

sudo apt-get install valgrind、実行するvalgrind myprogramと、メモリ割り当てのバグの 99% が明らかになります。

問題の少なくとも 1 つは_gridOne[i]、配列ポインターの上に行を割り当てていることです (する必要があります)。でコンパイルする-Werror -Wall -Wと、このような多くのエラーがコンパイル時に明らかになります。

于 2010-07-22T10:03:01.880 に答える
0

STL とベクトルを使用します。

class Grid
{
    std::vector<std::vector<char> >    grid1;
    std::vector<std::vector<char> >    grid2;

    public:
       Grid(int col,int row)
           : grid1(col, std::vector<char>(row))
           , grid2(col, std::vector<char>(row))
        {}
 };

すべて完了。

凝った外観にしたい場合は、ブースト マトリックスをご覧ください。

于 2010-07-22T17:21:37.303 に答える