0

我有一个添加向量和存储结果的功能,我不知道为什么我得到一个分段核心转储。好久没做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);
}
4

2 回答 2

6

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

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

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

于 2013-10-01T12:18:13.297 回答
4

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

for(i = 0 ; i < n; i++)
{
   c[i] = a[i] + b[i];
}
于 2013-10-01T12:18:34.150 回答