免费大量指针时的分段错误

时间:2013-03-21 09:45:19

标签: c arrays pointers malloc free

我的代码在小文件上运行时没有错误。但我在大输入(数百万行)上获得了段落错误。请参阅下面的一些代码:

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;

}

1 个答案:

答案 0 :(得分:0)

在每个malloc之后你应该检查malloc是否返回NULL(这意味着当堆已满时无法分配内存)。如果它返回NULL,通常会打印错误消息。如果你还想分配内存,你必须在释放一些已分配的内存后重试。

由于你的程序对于大文件失败,不需要详细阅读代码,它必须失败,因为它的可用内存耗尽而malloc返回NULL然后你试图在顶层函数中将结构元素保存在NULL地址findUnion。