初始化2D阵列时出现分段错误

时间:2013-09-27 20:02:34

标签: c segmentation-fault malloc multidimensional-array

我已经检查过我的代码正确地划分了内存空间,但是一旦我尝试将我的2D数组初始化为某些值然后总结这些值,我就会在2x2数组上收到分段错误。我想最终将我的代码扩展到更大的数组,但我甚至无法在这里工作。我知道关于malloc和2D数组有很多关于分段错误的帖子,但由于我的C知识刚刚开始,我一直无法找到一个帮助我解决问题的帖子。您可以给予任何帮助,或者如果您能指出我之前的问题,将不胜感激。谢谢!

#include <stdlib.h>
#include <stdio.h>
#include <math.h>

int main()
{
  double sum=0;
  int i,j;
  int N = 2;

  double **array;
  array = malloc(N * sizeof(double *));

 if(array == NULL) printf("Failure to allocate memory.\n");

 for(i=0; i<=N; i++)
    {
      array[i] = malloc(N * sizeof(double));
      if(array[i] == NULL) {
     printf("Failed to allocate memory for arr[%d].\n", i);
     exit(0);
     }
     }

 for(i=0; i<=N; i++)
  {
    for(j=0; j<=N; j++)
  {
    array[i][j] = 1.0/(i+j);
    sum = sum + array[i][j];
   }
   }

   return(0);
 }

2 个答案:

答案 0 :(得分:6)

你已成为一个经典失误的受害者:使用<=代替<

for(i=0; i<=N; i++)

那将初始化array [0],array [1]和MOST IMPORTANTLY数组[2](因为2&lt; = 2),但是你没有三个指针的malloc空间,只有两个。

这是你想要的:

for(i=0; i<N; i++)

它将遍历数组[0]和数组[1](总共两个条目)。

(不是说你没有其他的错误,但这绝对是其中之一。)

答案 1 :(得分:3)

您正在为NxN阵列分配空间,但在 for 周期中,您尝试访问(N + 1)个(N + 1)数组。您可以通过以下方式之一替换周期:

for(i=0; i<N; i++)

for(i=1; i<=N; i++)

鉴于您正在计算 1.0 /(i + j),您可以使用第二个,因为当i = 0,j = 0时,第一个将产生除零。但要注意,如果你使用第二个选项,你应该将索引移动1,如下所示: array [i-1] [j-1] ,因为它们总是从0开始。它更好使用第一个选项。