c分割核心转储?

时间:2013-10-01 12:16:11

标签: c arrays malloc

我有一个添加向量和存储结果的函数,我无法弄清楚为什么我会得到一个分段核心转储。暂时不做C:/

void add(int *a, int *b, int *c, int n){
   int i;

   for(i = 0 ; i < n; n++)
   {
     c[i] = a[i] + b[i];
     i++;
   }

}

int main() {
 // vector_size = 100000
 // vector_a init with 100000 values
 // vector_b init with 100000 values

 int *result = malloc(vector_size * sizeof(int));
 add(vector_a,vector_b,result,vector_size);
}

2 个答案:

答案 0 :(得分:6)

您正在增加n而非i,for循环应如下所示:

for(i = 0; i < n; ++i)
{
    c[i] = a[i] + b[i];
}

在您的代码中,变量i最终会大于vector_size,从而导致分段错误。

答案 1 :(得分:4)

以这种方式修复代码(你有一个无限循环):

for(i = 0 ; i < n; i++)
{
   c[i] = a[i] + b[i];
}