我很难找到这种内存泄漏。
我认为它与盆地
有关int numbasinsx(int size, double *f)
{
int maxBasin, maxRelabel, bcnt;
unsigned int newgene;
int *basin, *relabel;
int relabelcnt;
//
// find the basins
//
maxBasin = 1<<size;
basin = new int [maxBasin];
for (int gene=0; gene<maxBasin; gene++) basin[gene] = 0;
bool change = true;
bcnt = 0;
while (change) {
change = false;
for (int gene=0; gene<maxBasin; gene++) {
bool dominated = false;
for (int i=0; i<size; i++) { // for all neighbors
newgene = gene ^ (1<<i); // newgene is a neighbor 1 bit away
if (f[newgene] > f[gene]) dominated = true; // if neighbor is better mark it
if (basin[newgene]!=0) { // something to copy
if (f[newgene] > f[gene]) { // gene is dominated
if (basin[gene]==0 || basin[gene]<basin[newgene]) { // if not labeled or not lowest number
basin[gene] = basin[newgene]; // then label or relabel
change = true;
}
}
else if (f[newgene] == f[gene]) {
if (basin[gene]<basin[newgene]) {
basin[gene] = basin[newgene];
change = true;
}
}
}
}
if (! dominated && basin[gene]==0) {
// printf("max: %d %lg\n", gene, f[gene]);
basin[gene] = ++bcnt;
change = true;
}
}
}
//
// relabel the basins
//
maxRelabel = maxBasin/2+1;
relabel = new int [maxRelabel];
for (int gene=0; gene<maxRelabel; gene++) relabel[gene] = 0;
relabelcnt = 1;
for (int gene=0; gene<maxBasin; gene++) {
if (basin[gene]>=maxRelabel) printf("ERROR: trying to index %d into relabel array with max index of %d\n", basin[gene], maxRelabel-1);
if (relabel[basin[gene]]==0) {
relabel[basin[gene]] = relabelcnt++;
}
// printf("%d %lg %d\n", gene, f[gene], relabel[basin[gene]]);
}
// printf("%d\n", relabelcnt-1);
delete basin;
delete relabel;
return relabelcnt-1;
}
我将保留上述内容以帮助其他人,但带有向量的新代码现在位于http://codepad.org/KiV85Brw。向量运行时间比delete []版本慢得多,甚至对于大输入也是分段。我做错了什么
答案 0 :(得分:9)
如果您使用operator new[]
分配一堆字节,那么必须使用operator delete[]
来销毁它们:
basin = new int [maxBasin];
//.....
delete[] basin;
请注意,您使用relabel
执行相同的操作。
无论如何,对于这类任务,您应该使用std::vector
:
std::vector<int> basin(maxBasin), relabel(maxRelabel); // We haz no leaks
答案 1 :(得分:4)
new[]
必须后跟delete[]
,而不仅仅是delete
。您释放数组basin
和relabel
的代码都是错误的。
答案 2 :(得分:3)
basin
和relable
都是数组。使用 new
运算符在堆上分配数组时,删除数组的语法与删除单个变量的语法不同。正确的语法是:
delete[] basin;
delete[] relable;
我相信你所拥有的代码只是删除了每个数组的第一个元素。
答案 3 :(得分:1)
由于您要分配数组,请使用delete [] basin;
delete
运算符用于单个对象; delete []
用于多个对象(数组)。
答案 4 :(得分:1)
basin = new int [maxBasin];
对于数组,您应该使用operator delete []。另请查看relabel
。
看起来它是一个小的局部变量,你确定要使用动态分配吗?为什么?如果你不得不尝试unique_ptr。