在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
数组指针 和 指针数组
这两个名词可以说是经常搞混了
数组指针--> 数组的指针 就是前面讲的 指向数组a的指针p;
指针数组-->存满指针的数组 就是一个数组里面存的都是指针.----> 也是所谓的二级指针
数组指针就不讲了,见一维数组和指针.
那么指针数组呢?
首先,指针数组是 一个数组里面都是指针
第一步,我们需要一个数组
point[10] //我们定义了一个空间为10的数组
第二步,这个数组是什么类型的? 指针类型的
* point[10] //区别: int a[10] 中 数据元素是int型的,那我们现在需要指针型的,就把int换成 * .
还没完,第三步,数组里面的每个元素都是指针,但是指针就必须指向拎一个内存空间,那么这个空间有多大?
int *point[10] //表示有一个数组p,里面存放的都是指针类型的变量,然后这些指针都指向int大小的空间.
int *p[10] 就是指针数组.
从这里我们也发现,他的优先级是 以point为中心,从右往左 先p[] --> *p[] --> int *p[]
指针数组就是二级指针.
因为指针数组不单单又有它自己本身,还附带每个指针袁术指向的小空间.那么:
数组的地址是p,从数组数组的第一个元素是*p,第二个元素是*(p+1),第三个是...
那么,第一个元素指针所指向的小空间的内容就是 *(*(p)) 简写成 **p;
所以,对于二级指针**p 来说 p 是数组地址, *p 是数组里面的元素, **p 是数组里面指针指向的数据 .
从另一个角度理解 *p[10] 因为 p[10] 的指针形式是 *p 所以--> *(*p) 也符合定义
//指针数组的形参 -->二级指针 int func(int **p){ //... return 0;
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论