c语言二维数组指针

二维数组指针

定义一个指向 a 的指针变量 p:

int (*p)[4] = a;

1)  p  指向数组 a 的开头,也即第 0 行;p+1前进一行,指向第 1 行。

2) *(p+1)表示取地址上的数据,也就是整个第 1 行数据。

3) *(p+1)+1表示第 1 行第 1 个元素的地址。

*(p+1)单独使用时表示的是第 1 行数据,放在表达式中会被转换为第 1 行数据的首地址,也就是第 1 行第 0 个元素的地址,因为使用整行数据没有实际的含义,编译器遇到这种情况都会转换为指向该行第 0 个元素的指针;就像一维数组的名字,在定义时或者和 sizeof、& 一起使用时才表示整个数组,出现在表达式中就会被转换为指向数组第 0 个元素的指针。

4) *(*(p+1)+1)表示第 1 行第 1 个元素的值。很明显,增加一个 * 表示取地址上的数据。

原文

 

指针数组和二维数组指针的区别

二维数组指针,指向二维数组的指针

指针数组和二维数组指针在定义时非常相似,只是括号的位置不同:

  1. int *(p1[5]); //指针数组,可以去掉括号直接写作 int *p1[5];
  2. int (*p2)[5]; //二维数组指针,不能去掉括号

指针数组和二维数组指针有着本质上的区别:指针数组是一个数组,只是每个元素保存的都是指针,以上面的 p1 为例,在32位环境下它占用 4×5 = 20 个字节的内存。二维数组指针是一个指针,它指向一个二维数组,以上面的 p2 为例,它占用 4 个字节的内存。

posted @ 2020-04-22 17:13  天凉好个秋秋  阅读(699)  评论(0编辑  收藏  举报