C ++内存泄漏新增和删除

时间:2012-09-19 19:58:41

标签: c++ memory memory-leaks

我很难找到这种内存泄漏。

我认为它与盆地

有关
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 []版本慢得多,甚至对于大输入也是分段。我做错了什么

5 个答案:

答案 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。您释放数组basinrelabel的代码都是错误的。

答案 2 :(得分:3)

basinrelable都是数组。使用 new 运算符在堆上分配数组时,删除数组的语法与删除单个变量的语法不同。正确的语法是:

delete[] basin;
delete[] relable;

我相信你所拥有的代码只是删除了每个数组的第一个元素。

答案 3 :(得分:1)

由于您要分配数组,请使用delete [] basin; delete运算符用于单个对象; delete []用于多个对象(数组)。

答案 4 :(得分:1)

   basin = new int [maxBasin];

对于数组,您应该使用operator delete []。另请查看relabel

看起来它是一个小的局部变量,你确定要使用动态分配吗?为什么?如果你不得不尝试unique_ptr。