在开始本次内容开始之前,我们需要对数组有更深入的了解。
arr本身是一个数组名,
数组名代表三个含义:
1) 数组第一个元素的地址
2) 整个数组的地址
3) 数组的名字
#include<stdio.h>
int main()
{
int arr[10] = { 0,1,2,3,4,5,6,7,8,9 };
printf("%p %p\n", arr, arr+1); //002FFD48 002FFD4C
printf("%p %p\n", &arr, &arr+1); //002FFD48 002FFD70
return 0;
}
对于1)和2),虽然arr的值和&arr是一样的,但arr+1指向下一个元素,&arr+1指向下一个数组。
指针数组
指针数组,就是说首先是一个数组,而数组的元素是指针,也就是说,如果数组元素都是相同类型的指针,则称这个数组为指针数组。所谓相同类型的指针是说指针所指向的对象类型是相同的。指针数组中的每一个元素均为指针。指针数组常适用于指向若干字符串,这样使字符串处理更加灵活方便。其本质相当于一个二级指针。
int *arr[4]={ null };//*先于int 结合标明其类型为整型指针,再往后看[4]表示其为大小为4的数组
数组指针
顾名思义:就是数组的一个指针,先定义一个数组,再让一个指针指向他。
int (*p)[4]; ///()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n
二级指针
即指向指针的指针
int *p=nullstr;
int **pp=&p;
区别
#include<stdio.h>
int main()
{
int arr[3][2] = { 0,1,
2,3,
4,5};
int* p = arr[0];
int** pp = &p;
int(*q)[2] = arr;
printf("%d %d\n", **pp, pp[0][0]); // 0 0
printf("%d %d\n", **q, q[0][0]); // 0 0
printf("%d %d\n", *(*pp)+1, pp[0][1]);// 1 1
printf("%d %d\n", *(*q)+1, q[0][1]);// 1 1
//printf("%d %d\n", **(pp + 1), pp[1][0]);//无法执行,但没关系
printf("%d %d\n", **(q+ 1) , q[1][0]);// 2 2
return 0;
}
显而易见的区别就是其自加能力,对于二级指针来说,其指向的一个指针,其大小为4字节,自增自减时只会改变四字节,而对于数组指针来说,其指向的是一个数组,会改变n*sizeof(datatype)个字节。