2010-09-10 73 views
1

我有一个令人困惑的问题 - 对我来说,至少,这可能是非常简单,我错过了一些东西。我正在尝试初始化一个可变大小的二维数组,该数组是一个结构的一部分。我没有问题为阵列分配内存,但是当我尝试将字符分配给阵列或打印它们时,我收到了意外的结果=/C程序:打印时的方括号二维字符数组

我最后一次尝试表明,无论何时将字符分配给阵列,当我打印'['将被打印...这是我第一次实际上能够打印什么。我以前的尝试返回seg故障。这是代码,我错过了什么。谢谢。

typedef struct world_map { 
    char ** map_array; 
    int X, Y; 
} MAP_s; 
// 
MAP_s * map; 

int init_map_array(void) { 
    int i; // temp 
    map = malloc(sizeof (MAP_s)); 
    map->X = 20; // Columns 
    map->Y = 10; // Rows 
    // 
    map->map_array = malloc(map->Y * (sizeof (char *))); 
    // 
    if (map->map_array == 0) { 
     printf("ERROR: out of memory!"); 
     return -1; 
    } else { 
     for (i = 0; i < map->Y; ++i) { 
      map->map_array[i] = malloc(map->X * sizeof (char)); 
      if (map->map_array[i] == 0) { 
       printf("ERROR: out of memory!"); 
       return -1; 
      } 
     } 
    } 
    int curr_pos_x, curr_pos_y; 
    int limit_x = map->X; 
    int limit_y = map->Y; 
    // 
    for (curr_pos_y = 0; curr_pos_y < limit_y; ++curr_pos_y) { 
     for (curr_pos_x = 0; curr_pos_x < limit_x; ++curr_pos_x) { 
      map->map_array[curr_pos_y][curr_pos_x] = "#"; 
     } 
    } 
    return 1; 
} 

int draw_map(void) { 
    int curr_pos_x, curr_pos_y; 
    int limit_x = map->X; 
    int limit_y = map->Y; 
    // 
    for (curr_pos_y = 0; curr_pos_y < limit_y; ++curr_pos_y) { 
     for (curr_pos_x = 0; curr_pos_x < limit_x; ++curr_pos_x) { 
      printf("%c", map->map_array[curr_pos_y][curr_pos_x]); 
     } 
     printf("\n"); 
    } 
} 

int main(void) { 
    init_map_array(); 
    draw_map(); 
    // 
    printf("STRUCT: %i\n", sizeof (map)); 
    printf("X: %i\n", sizeof (map->X)); 
    printf("Y: %i\n", sizeof (map->Y)); 
    printf("ARRAY: %i\n", sizeof (map->map_array)); 
return (EXIT_SUCCESS); 
} 

作为边注,在端部4的那些的printf所有返回“4”,我相当肯定,如果一个结构包含3种元素,其各自是4个字节,它应该是大于4个字节本身...

+0

该结构的大小将是12个字节;但是,您正在打印MAP_s *类型的地图的大小,因此地图只有4个字节。 – 2010-09-10 08:20:40

回答

1

似乎为我工作得很好,但有一个错误(不知我的GCC是足够“智能”来处理它,但它仍然是一个错误):

map->map_array[curr_pos_y][curr_pos_x] = "#"; 

一个char *(指针分配给字符在数据段)而不是一个字符,当然会导致怪异的字符。将"#"更改为'#',它应该可以工作。

此外,关于你的printf s的结尾:他们应该是这样的:

printf("STRUCT*: %lu\n", sizeof (map)); // Prints sizeof(MAP_s *) == sizeof(void *) == 4; 
printf("STRUCT: %lu\n", sizeof (*map)); // Prints sizeof(MAP_s) == 16 on my system (iMac w/ Mac OS X), 
     // alignment and native pointer size might give you different values. 
printf("X: %d\n", map->X); // Prints the X dimension. No sizeof. 
printf("Y: %d\n", map->Y); // Prints the Y dimension. No sizeof. 

不能打印在编译时map->map_arraysizeof作品的大小,只能返回常数在编译时已知大小的类型。确定map_array大小的唯一方法是将您在malloc中给出的大小参数保存在变量中。

1

尝试

map->map_array[curr_pos_y][curr_pos_x] = '#'; 

,而不是

map->map_array[curr_pos_y][curr_pos_x] = "#"; 

map->map_array[curr_pos_y][curr_pos_x]的类型为char,您正在为其分配字符串常量。

+1

谢谢,我是个白痴-_- – FrostedPixel 2010-09-10 08:14:11