请考虑以下代码段:
void init ()
{
int i,j;
ioctl(0, TIOCGWINSZ, &w);
X=w.ws_col;
Y=w.ws_row - 9;
printf("X=%d,Y=%d\n",X,Y); // X and Y looks good, 144 and 32
getch();
Terrain=malloc(Y);
for(i=0;i<Y;i++)
Terrain[i]=malloc(X);
printf("Created terrain\n"); //OK
Terrain[6][0]=getch();
printf("%x\n",Terrain[6][0]); getch(); //No problem accessing Terrain[6][0]
for (i = 0; i < Y; i++)
{
for (j = 0; j < X-1; j++)
{
if ((i == 0) || (j == 0) || (j == (X - 2)) || (i == (Y - 1)))
{printf("%d:%d\n",i,j);Terrain[i][j] = '#';printf(" '#'OK\n");} //seg fault in this line for i=6,j=0
else
{printf("%d:%d\n",i,j);Terrain[i][j] = ' ';printf(" '_'OK\n");}
}
printf("%d:%d",i,X-1);
Terrain[i][X - 1] = '\0';printf(" 'o'OK\n");
}
}
Out put就是这样......
...
5:141
'_' 行
5:142
'#' 行
5:143'o'OK
6:0
分段错误(核心转储)
dipto @ dipto-VirtualBox的:〜$
如果我使用相同大小的静态数组,即144和32,则没有问题 我错过了还是忽略了什么?
答案 0 :(得分:3)
您没有显示关键变量,例如X,尤其是Y.
分配内存时,通常需要一个乘数来计算数组中每个成员的字节大小。 “短”通常需要2.“int”这些日子很棘手,可能是4或8. Terrain=malloc(Y*sizeof(Terrain[0]))
行。
如果没有倍增器,你就不会分配足够的内存,你的生存取决于内存的分配方式以及超出实际内存结束时踩踏的内容。