C与C++基础–数组指针与指针数组
C与C++基础–结构体struct和typedef struct 区别
C与C++基础–函数
C与C++基础–内存管理
数组指针:
数组指针也成为行指针,
数组指针,就是一个指针,指向一个一维数组。
定义 int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
代码实例:
#include <stdio.h>
int a[3][4];
int (*p)[4];//定义一个数组指针
int main()
{
a[0][0] = 100;a[0][1] = 101;a[0][2] = 102;a[0][3] = 103;
a[1][0] = 200;a[1][1] = 201;a[1][2] = 202;a[1][3] = 203;
a[2][0] = 300;
p = a;
printf("p %d\n",p[0][0]);
p++;
printf("p %d\n",p[0][0]);
return 0;
}
输出结果:
p 100
p 200
画图分析:
指针数组:
指针数组就是一个数组,数组的每个元素就是一个指针。
定义 int p[n];
[]优先级高,先与p结合成为一个数组,再由int说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1是错误的,这样赋值也是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]…p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样 p=a; 这里p表示指针数组第一个元素的值,a的首地址的值。
代码实例:
#include <stdio.h>
int main()
{
int arr[] = {100,200,300};
int *p[3];//定义指针数组
for(int i = 0; i<3;i++){
p[i] = &arr[i];
}
for (int i = 0; i<3; i++) {
printf("指针 %d\n",p[i]);
}
printf("---------------我只是一个分割线--------------\n");
for (int i = 0; i<3; i++) {
printf("数组 %d\n",*p[i]);
}
return 0;
}
输出结果:
数组 -272632404
数组 -272632400
数组 -272632396
---------------我只是一个分割线--------------
数组 100
数组 200
数组 300
画图分析:
总结:
数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。