我正在尝试编写一个程序来添加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
, b
和c
为全局:
#define M 1000
#define N 1000
static int a[M][N];
static int b[M][N];
static int c[M][N];
int main() {
/* ... */
}
注意,如果这样做,M
和N
不能是变量。
如下所示全局声明这些矩阵,您的问题将得到解决。这通常是因为全局变量从堆中获得内存,而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 ;
}