4

我正在 Linux 上开发一个在矩阵上运行的程序。我在一段代码中遇到问题,该代码生成矩阵的随机值(它会生成段错误)这是触发我的问题的一段代码。

#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#define INFINITO 10
#define MAX 11
#define MR 100
#define MC 100
#define MEMBER 1
#define NONMEMBER 0

double shortpath(double MatQuad[][MR+MC], int, int ,int precede[]);


int main(){

int d;
int c1, c2, i, j, p , h, l, k, x, mrr, rf, cf;
double X[MR][MC], F1k[MR+1][MC];
double MatQuad[MR+MC][MR+MC];
double P[MC][MC][MC];
int precede[MR+MC];
double best_Delta, Delta;
int best_i, best_j, best_h, best_l;

srand(8);
   for(j=0; j<MR; ++j){
     for(h=0; h<MC; ++h)
       X[j][h]=(rand()% MAX)*0.1;
   }

使用 Valgrind,我在线获得

srand(8);

错误信息:

访问不在地址 0x7FE7EA0B8 [PID: 2484] 的映射区域内

您认为语义或......有什么问题吗?我想给 srand 一个系统时钟所取的值,但我的尝试没有成功。

4

1 回答 1

7
double X[MR][MC], F1k[MR+1][MC];     // 80KB + 80.8KB
double MatQuad[MR+MC][MR+MC];        // 320KB
double P[MC][MC][MC];                // 8MB
int precede[MR+MC];                  // 800B 

我怀疑你的堆栈数据太多了。堆栈空间有限。确切的大小取决于平台和编译器;如果您在数百 KB 范围内,那么您正在与灾难调情。像这样的大型数组作为静态数据或在堆上会更好。尝试static为每一个添加限定符,或使用malloc().

于 2013-03-20T15:09:58.803 回答