0

我收到了一些代码来“生产”。我运行了一个内存泄漏检查器,它在下面的“for”循环中调用以下行作为内存泄漏。

someStruct->arrayMap = new std::list<BasisIndex>*[someStruct->mapSizeX];
for(int i=0; i<someStruct->mapSizeX; i++){  
    someStruct->arrayMap[i] = new std::list<BasisIndex>[someStruct->mapSizeY];
}

以下是数组映射的声明方式:

struct SomeStruct{
    int mapSizeX;
    int mapSizeY;
    std::list<BasisIndex>** arrayMap;
};

以下是它的几个用法:

someStruct->arrayMap[xVal][yVal].push_back(tempIndex);

for(it = someStruct->arrayMap[xVal][yVal].begin(); it != someStruct->arrayMap[xVal][yVal].end(); it++){
    ...
}

在我杀死它之前,内存泄漏检查器转储了 5 分钟。然后我在清理例程中添加了以下代码,但它仍然转储出 150 个警告,所有这些警告都指向顶部 for 循环中的代码行。

for(int x=0; x<someStruct->mapSizeX; x++){
    for(int y=0; y<someStruct->mapSizeY; y++){
        someStruct->arrayMap[x][y].clear();
        someStruct->arrayMap[x][y].~list();
    }
}

std::list<BasisIndex> ** temp = someStruct->arrayMap;
delete temp;

如何完全删除与此数组映射关联的内存?

4

2 回答 2

3

以与分配对象相反的顺序解除分配对象。

分配:

someStruct->arrayMap = new std::list<BasisIndex>*[someStruct->mapSizeX];
for(int i=0; i<someStruct->mapSizeX; i++){  
    someStruct->arrayMap[i] = new std::list<BasisIndex>[someStruct->mapSizeY];
}

重新分配:

for (int i=0; i<someStruct->mapSizeX; i++){
    delete[] someStruct->arrayMap[i];
}
delete[] someStruct->arrayMap;
于 2011-05-31T22:59:36.037 回答
3

someStruct->arrayMap[x][y].~list();<-- 你不应该手动调用析构函数。(我什至不知道在没有首先使用placement new 时这样做是有效的......)你需要使用它delete

于 2011-05-31T23:01:28.737 回答