程序中出现分段错误(堆核)

Segmentation fault (core dumped) in program

本文关键字:堆核 错误 分段 程序      更新时间:2023-10-16

我正在尝试编写一个程序来添加2个矩阵。

如果我增加矩阵的大小,我得到以下错误:

Segmentation fault (core dumped)
下面是我的代码:
#include <iostream>
using namespace std;
int main()
{
  int thrd ;
  int m = 1000 ;
  int n = 1000 ;
  int a[m][n] ;
  int b[m][n] ;
  int c[m][n] ;
  for(int i=0 ; i<m ; i++)
  for(int j=0 ; j<n ; j++)
        {
         a[i][j] = 0 ;
         b[i][j] = 0 ;
        }
  for(int i =0 ; i<m ; i++)
    {
      for(int j=0 ; j<n ; j++)
        c[i][j] = a[i][j] + b[i][j] ;
    }
  return 0 ;
}

那我该怎么办呢?

看起来您用这么大的矩阵耗尽了堆栈内存。我建议静态分配,即声明a, bc为全局:

#define M 1000
#define N 1000
static int a[M][N];
static int b[M][N];
static int c[M][N];
int main() {
    /* ... */
}

注意,如果这样做,MN不能是变量。

如下所示全局声明这些矩阵,您的问题将得到解决。这通常是因为全局变量从堆中获得内存,而main中的变量从堆栈中获得内存。

#include <iostream>
#define max 1000
int a[max][max] ;
int b[max][max] ;
int c[max][max] ;
using namespace std;
int main()
{
  int thrd ;
  int m = 1000 ;
  int n = 1000 ;
  for(int i=0 ; i<m ; i++)
  for(int j=0 ; j<n ; j++)
        {
         a[i][j] = 0 ;
         b[i][j] = 0 ;
        }
  for(int i =0 ; i<m ; i++)
    {
      for(int j=0 ; j<n ; j++)
        c[i][j] = a[i][j] + b[i][j] ;
    }
  return 0 ;
}