首先用几个表达式直观的感受一下什么是指针数组以及数组指针。
一.表达式
int *p[10];//指针数组 int (*p)[10]//数组指针
有了直观的感受那么我们具体分析,指针数组以及数组指针是怎么定义的。
1).指针数组:实质是数组,数组中存放的元素是指针。
2).数组指针:实质是指针,指针变量中存放的是数组首元素的地址。
二.分析小程序理解数组指针
int main() { char a[5] = { ‘A‘, ‘B‘, ‘C‘, ‘D‘ }; char(*p3)[4] = &a; char(*p4)[5] = a; system("pause"); return 0; }
1).编译上述程序
(1).第一个警告告诉我们char (*)[4]和char (*)[5]的数组下标不同,只需要将‘4’改成‘5’即可。
(2).第二个警告告诉我们char (*)[5]与char *的间接级别不同。为什么呢?原因为,字符数组char a[5]的类型的类型是char *,指针指向字符。而char (*p4)[5]的类型是char (*)[5],指针指向数组。
(3).如果要输出(p3+1)的地址呢?会是什么呢?同样我们用代码来分析。
#include<stdio.h> int main() { char a[5] = { ‘A‘, ‘B‘,‘C‘,‘D‘ }; char(*p3)[5] = &a; //char(*p4)[5] = a;//char(*)[5]和char*的间接级别不同 int size = sizeof(a) / sizeof(a[0]); int i = 0; for (i = 0; i < 6; i++) { printf("%p\n", &a[i]); } printf("++++++%d", size); printf("-------%p\n", p3+1); system("pause"); return 0; }
为了分析我将字符数组的地址也都输出了。并且多输出一块空间以便于分析。我们不难发现(p3+1)的地址是向后整整偏移了一个字符数组的大小,那么我们也就可以理解,数组指针的含义了。
注意:字符数组后面也是有‘\0‘的!!!不单单是字符串。这一点我们可以用sizeof求数组大小,同时在使用memcpy内存拷贝函数的时候尤为重要。你们肯定会有疑问,内存拷贝函数是以(size_t count)作为拷贝条件,为什么还要有拷入‘\0‘?原因很简单,如果不将‘\0’拷入的话,结果还是字符串么?能不能正确使用strlrn函数?所以,这就是为什么要将‘\0’拷入的原因了。很重要!
三.自测小程序
#include <stdio.h> int main() { int a[4] = { 1, 2, 3, 4 }; int *ptr1 = (int *)(&a + 1);//4 int *ptr2 = (int *)((int)a + 1); printf("%x,%x", ptr1[-1], *ptr2);//*(ptr1+(-1)) system("pause"); return 0; }
输出的是什么?
以上就是本人在学习过程中的一些经验总结。当然,本人能力有限,难免会有纰漏,希望大家可以指正。
时间: 2024-10-17 13:09:55