0

我的代码在小文件上运行没有错误。但是我在大输入(数百万行)上遇到了段错误。请看下面的一些代码:

element* unionFind(void *data)
{
    element *retVal = NULL;
    retVal = (element *)malloc(sizeof(element));
    retVal->data = data;
    retVal->rank = 0;
    retVal->leader = retVal;
    return retVal;
}

主要:
...

int main (int argc, char* argv[])
{   
char str[2048]; 
char* v_S = NULL; 
struct set *s_v = NULL;

*计算输入的行数

long *v_L = (long *)malloc(sizeof(long)*ct_lines);
element **v = malloc(sizeof(element)*ct_lines) ;

while(fgets(str,sizeof(str),fp) != NULL)
{
     v_S = strtok(str,":");        

     v_L[i] = atol(v_S);
         v[i] = unionFind(&v_L[i]);
     s_v = add_vertex(v_L[i], v[i]);

     i++;
}

fclose(fp);

for (i = 0; i < ct_lines; i++) //Here segfault
    {
    free(v[i]); v[i] = NULL;
    }

free(v); v = NULL;
free(v_L); v_L = NULL;

}
4

1 回答 1

0

在每个 malloc 之后,您应该检查 malloc 是否返回 NULL(这意味着由于堆已满而无法分配内存)。如果返回 NULL,一般会打印错误信息。如果您仍然想分配内存,则必须在释放一些已分配的内存后重试。

由于您的程序因大文件而失败,因此无需详细阅读代码,它一定会失败,因为它的可用内存不足并且 malloc 返回 NULL,然后您试图将结构元素保存在顶部函数 findUnion 中的 NULL 地址处。

于 2013-03-21T09:58:04.023 回答