【发布时间】:2011-05-31 22:56:12
【问题描述】:
我收到了一些代码来“生产”。我运行了一个内存泄漏检查器,它在下面的“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;
如何彻底删除与此数组映射关联的内存?
【问题讨论】:
-
改用
std::vector<std::vector<std::list<T> > >。使用new分配 STL 容器是可怕的。 (我所说的可怕是指杀死可怕的小狗) -
@Billy:实际上情况更糟。它正在杀死小猫!
-
我没有太多使用这些容器的经验。为什么这是一个糟糕的做法?这段代码需要尽可能快,但内存使用不是问题。谢谢
-
因为没有理由动态分配它们。改为使它们成为自动变量。这与容器无关,但通常与 C++ 中对象的使用方式有关。如果你在现代 C++ 中一直在搞乱指针,那就有问题了。这就是
scoped_ptr、unique_ptr、shared_ptr、auto_ptr和朋友们的目的。 (当然,如果您要与一些总是不同的 C API 交互;)) -
当您使用它时,您可能会更喜欢
std::vector而不是std::list。
标签: c++ memory-leaks stdlist