数组指针
数组指针的写法;
int a[3] = {1,2,3};
int (*p)[3]; // 真正意义上的数组的指针,强调的是类型,数组的个数,偏移值是偏移了整个数组的大小
p = a;
指针数组的写法;
int a[3] = {1,2,3};
int *p2;
p2 = a;
看看数组指针和指针数组的输出地址的运行结果;
int a[3] = {1,2,3};
int b;
int (*p)[3]; // 真正意义上的数组的指针,强调的是类型,数组的个数,偏移值是偏移了整个数组的大小
p = a;
int *p2;
p2 = a;
printf("数组的地址%p\n",a);
printf("数组的地址%p\n",&a[0]);
printf("p数组的地址%p\n",p);
printf("p2数组的地址%p\n",p2);//p2数组的地址0060FEDC
1.通过数组名打印地址。
2.通过数组首元素打印地址。
3.通过数组指针的指针打印数组。
4.通过指针数组的指针打印地址。
看看数组指针(p++)和指针数组(p2++)的区别
int a[3] = {1,2,3};
int b;
int (*p)[3]; // 真正意义上的数组的指针,强调的是类型,数组的个数,偏移值是偏移了整个数组的大小
p = a;
int *p2;
p2 = a;
printf("数组的地址%p\n",a);
printf("数组的地址%p\n",&a[0]);
printf("p数组的地址%p\n",p);
printf("p2数组的地址%p\n",p2);//p2数组的地址0060FEDC
printf("==========区别==========\n");
printf("p++的结果是;%p\n",++p); //p++的地址结果是;0060FEE8
printf("p2++的结果是;%p\n",++p2);//p2++的结地址果是;0060FEE0
p++ 打印的地址是 0060FEE8,比原地址0060FEDC 向右偏移了12个字节(注意;此数组中有三个整型数据。1,2,3),
p2++打印的地址是0060FEE0,比原来地址0060FEDC向右偏移了4个字节。
数组指针和指针数组的区别;
数组指针++ ;偏移整个数组的字节,例如;数组有三个整型数据,那么一个整型变量占4个字节,那数组指针++ 就偏移12个字节。
指针数组++;偏移一个数组元素的字节。