木妖喵
2016-12-08 08:04
采纳率: 37.5%
浏览 1.6k
已采纳

C语言二维数组内存是怎么分配的?

为什么这段代码的执行结果是这样?

    int (*a)[2];
    int b[2][2];    
    printf("size of first element of b is %d\n",sizeof(b[0][0])) ;
    a = b;
    printf("size of first element of a is %d",sizeof(a[0][0])) ;

size of first element of b is 4
size of first element of a is 40

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • job_baiqiang 2016-12-08 08:49
    已采纳

    二维数组在内存中其实是一个平坦的一维数组,下面具体说明:
    int arr[3][5] 和 int arr[15] 所使用的内存区大小是一样的,都是15*sizeof(int)个字节。
    如果你做下面这样一个定义:
    union{
    int a[3][5];
    int b[15];

    }U;

    你会发现
    U.a = &U.b
    U.a[0] == &U.b[0]
    U.a[1] == &U.b[5]
    U.a[2] == &U.b[10]
    &U.a[2][3] == &U.b[13]

    规律是: &U.a[m][n] == &U.b[m*5+n],其中5就是数组a的第二维度。
    实际上,二维数组在运行时也是用这样的公式转化为对一维数组的访问。

    点赞 打赏 评论
  • shen_wei 2016-12-08 08:47

    VS2008

    测试

    size of first element of b is 4   //b[0][0] int 类型 = 4
    
    size of first element of a is 4  //a[0][0] int 类型 = 4
    
    点赞 打赏 评论
  • u010273936 2016-12-08 09:01

    二维数组同一维数组是相似的, 数组的内存核心是连续存储, 你可以把二维数组看到一个有n行n列的表格。

    点赞 打赏 评论
  • ctyilyx 2016-12-08 09:30

    二维数组和一维数组的内存分配都是连续的,你可以把二维数组看作一维数组,只不过查询方式不同

    点赞 打赏 评论
  • 张嫩嫩 2016-12-08 09:59
        int (*a)[2]; //数组指针
        int b[2][2];    //数组指针  int b[2][2] = int b[][2]  = int (*b)[2]
        int *c[2]; // 这是指针数组 因为[]优先级比*高 也可以写成 char **c
    

    //这a,b都是指针类型 指针就是占四个字节的内存 c是数组类型

    点赞 打赏 评论

相关推荐 更多相似问题