我在codeblocks上写了一些c代码。它在Windows上运行得非常好 但在Linux上给出了分段错误。为什么?
这是主要的。我用3个库和opencells方法调用递归方法。
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(int argc , char *argv[])
{
srand(time(NULL));
int size=atoi(argv[1]),trial=atoi(argv[2]); //! program basladıgında gelen argumanlar
int i,j; //! dongu degişkenleri
int **matrix = (int **)malloc(size * sizeof(int)); //!matriksin 1 boyutunu dinamik olarak yarattık
int *counters = (int *)malloc(trial * sizeof(int)); //! buda counterları tutcagımız array
for (i=0; i<size; i++)
matrix[i] = (int *)malloc(size * sizeof(int)); //! 2. boyutada yarattık
for(i=0;i<size;i++)
for(j=0;j<size;j++) //! matrixsi sıfırla saçma sapan degerler geliyo yoksa
matrix[i][j]=0;
for(i=0;i<trial;i++)
{
counters[i]=opencells(matrix,size); //!Random kapı açan ve bunun sayısını donduren fonksyon
}
printboard(matrix,size,trial,counters); //!Output.txtye yazdır
for (i=0; i<size; i++)
free(matrix[i]); //! ramden aldıgımız yerleri sal gitsin
free(matrix); //! bosu bosuna makinayı zorlamayalım
return 0;
}
答案 0 :(得分:3)
int **matrix = (int **)malloc(size * sizeof(int));
将:(int)更改为(int *)
int **matrix = (int **)malloc(size * sizeof(int*));
因为sizeof(int)和sizeof(int *)可能不同,所以当访问未分配的内存时,程序可能会崩溃。
答案 1 :(得分:1)
int **matrix = (int **)malloc(size * sizeof(int));
将(int)
更改为(int*)
int **matrix = (int **)malloc(size * sizeof(int*));
在释放内存的同时使用
free(matrix[i]);
free(counters);
答案 2 :(得分:0)
int **matrix = (int **)malloc(size * sizeof(int));
你在这里分配错误的内存量。您需要sizeof(int*)
,但需要sizeof(int)
。
在Windows上,int和int *都是32位大。在linux上,这可能会有所不同,从而导致程序因访问未分配的内存而导致分段错误。