srand() инициирует доступ не в отображенной области

Я разрабатываю для Linux программу, которая работает на матрицах. Я получаю проблемы в куске кода, который генерирует случайные значения матрицы (он генерирует ошибки seg). Здесь фрагмент кода, который вызывает мои проблемы.

#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 значение, принятое системными часами, но мои попытки не увенчались успехом.

1 ответ

Решение
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 

Я подозреваю, что у вас слишком много данных в стеке. Количество стеков ограничено. Точный размер зависит от платформы и компилятора; если вы находитесь в диапазоне сотен килобайт, вы заигрываете с катастрофой. Большие массивы, подобные этим, лучше использовать в качестве статических данных или в куче. Попробуйте добавить static квалификатор для каждого из них, или присвоение им malloc(),

Другие вопросы по тегам