C语言进阶--DAY3
2021-06-16 09:06
标签:实验 二级指针 数组访问 单元格 帮助 讲解 语言 元素 指定 主要讲解数组和指针有关问题 1. 数组名的本质是一个常量指针 2. 内存编址的最小单位是字节,对于变量来说,一个变量可以取1、2、4、8等字节,对变量取地址来说,取的是低位字节的地址,在32位机中其对变量取地址就是4,不管其占几个字节。如下例 经过分析我们可以得出:指针的大小为4 3. 指针的本质:一个有类型的地址 以上实验说明指针是一个有类型的地址,常量指针 4. int p中,*号起的作用是指针的声明以及指定大小,类型决定寻址能 对于这个*号,注意如下的情况 int *p=&data;(1) printf(“%x\n”,*p);(2) (1)(2)两处的*是不一样的,(1)处的是指针的声明,(2)处的于与&data之间的引用和解引用的关系 5. 指针的运算,指针的+1和数值的+1是不一样的,观察下列程序 输出结果分别为:0x15, -5, 5 注意到第一个输出结果是指针的相加,步长为4,后两个为数值的加减,步长为1 6. 数组名作为成员访问的时候就是一个一级指针, & 和 * 实现了一级指针(数组名)到数组指针之间的切换 输出的结果为: arr = 0xbffd24dc arr+1 = 0xbffd24e0 &arr = 0xbffd24dc &arr+1 = 0xbffd24f0 *&arr = 0xbffd24dc *&arr+1 = 0xbffd24e0 7. 为了帮助理解数组在内存中的线性存储,做以下练习 由已学知识,数组在内存中的存储如下 a代表数组名,本来是一次跳动的格数为4,当对其取地址后,&a+1直接跳到蓝色的箭头那里,ptr1[-1]也可以写做*(ptr1-1),即向下移动4个单元格,因此移动到绿色箭头处,从绿色箭头开始向上打印出四个单元格,即5 对a进行强转即(int)a使得其每次跳动的格数为1,即(int)a+1跳转到紫色箭头处,由此开始向上打印4个单元格,即2000000; 8. 二级指针: char ch=’m’; char *pc=&ch; char* *ppc=&pc 此处对两个*的解释为:*ppc代表此为一个指针,char*表示此指向类型是一个指针类型 通过二级指针,实现了对数据空间的间接访问,如下所示 通过二级指针,可以改变一级指针的指向问题,见下列例子 注意:想要改变指针指向的内容,就必须要传递指针的地址,因此会出现二级指针 通过一级指针可以改变0级指针指向问题 通过二级指针可以改变一级指针指向问题 通过三级指针可以改变二级指针指向问题 8. 通过对二级指针,改变了一级指针的指向问题,也叫对一级指针的初始化问题 如上所见,指针p原本指向一个空指针,改变指向后使其指向一个有200个字节的空间,也可以看作是对其的一次初始化 9. 一级指针和二级指针的步长 一级指针的步长是与其类型相关的,二级指针的步长是固定的4,扩展:二级以上的指针的步长都是4 long long* *pp=&p;但凡有long long*的都是一个指针的大小,因此步长是4 10. 指针数组(字符指针数组):指针数组的本质是数组,数组中的每一个成员是一个指针 char * pARR[10]={“apple”,”banana”,”orange”}; 数组指针:本质是一个指针,int (*p)[4]—其本质应为int[4] *p,可见本质是一个指针 10. 二级指针访问指针数组 由于指针数组的本质就是一个数组,因此在学习时可以类比数组的访问,数组访问方法:下标访问(偏移)以及指针访问 等价性: int arr[10]={1,23,4}; int *p=arr; //此处的等价性为:arr即为数组的首地址, &arr[0] à&int àint * 由于在数组中我们常常用指针来进行访问,因此我们想用指针来访问指针数组 类比利用一级指针对数组进行访问,可以得出利用指针对指针数组的访问 对于char * *p=pa来说,pa 相当于&pa[0]à&char *àchar **即为一个二级指针 pa和**p完全等价的原因: 其中箭头代表指向关系 pa代表指针数组的首元素地址,pa+1每次加4,char*+1也是每次加4,在图中表示一个单元格的范围 同时,由于p=pa,因此pa[1]代表的地址为0x14c0b,p[1]代表的地址也是0x14c0b C语言进阶--DAY3 标签:实验 二级指针 数组访问 单元格 帮助 讲解 语言 元素 指定 原文地址:https://www.cnblogs.com/Cucucudeblog/p/9726507.html
上一篇:php数组去重(一维数组)
下一篇:c/c++ 数组的智能指针 使用