指针数组
定义理解
指针数组:指针数组可以说是“指针的数组”,顾名思义,首先这是一个数组,其次“指针”修饰这个数组,也就是说这个数组里的所有元素都是指针类型,在32位系统中,指针占4个字节。
首先我们定义一个指针数组,既然是一个数组,那么我们起名为arr
char* arr[3] = { "zhangsan","lisi","wangwu" };
//这里的arr为一个指针数组
//它有三个元素,每一个元素为一个char*类型的指针
//每一个char*类型的指针存放着对应字符串的首元素地址
这个数组有多大呢?答案是12个字节。
因为这个数组存放了三个元素,每一个元素为一个char*类型的指针,占用4字节,因此arr占用了12个字节大小。
数组指针
定义理解
数组指针:数组指针可以说是“指向数组的指针”,顾名思义,首先这是一个指针,其次“数组”修饰这个指针,也就是说这个指针指向一个数组的首地址,或者说这个指针存放了一个数组的地址(数组的地址和数组首元素的地址一样)。
首先我们定义一个指针,既然是一个指针,那我们起名为p
char(*p)[3];
//这里的p先和*结合,因此p是一个指针变量
//p指向的是一个大小为3的一个char类型的数组
//p是一个指针,指向一个数组
注:
- [ ]的优先级要高于* ,所以必须要加上()来保证p先和*结合
- 数组指针加1会跳过整个数组
如下面程序:
int arr[5] = { 1,2,3,4,5 };
//arr+1--->指向了数组的第二个元素
//&arr+1--->指向了5的后面,也就是跳过了整个arr数组