《C语言程序设计》第5章指针.ppt
《《C语言程序设计》第5章指针.ppt》由会员分享,可在线阅读,更多相关《《C语言程序设计》第5章指针.ppt(45页珍藏版)》请在三一办公上搜索。
1、第五章 指 针Pointer,5.1 指针的基本概念,指针是C语言的重要特征,是C语言访问内存数据和程序的灵活和有效的手段。,C语言的指针支持:函数的地址调用;动态分配内存;数组的地址引用。,内存、地址、指针(Memory,Address,Pointer),内存存放了计算机正在运行的程序和程序正在使用的数据。内存的基本单元是字节(Byte)。,为了访问内存单元,CPU给每个内存单元一个编号,该编号称为该内存单元的地址。,变量是程序中可以改变的量,当说明变量时,系统将为其在内存中开辟相应得内存单元。由此确定变量的地址及内存中的表示方式。,2000H,2001H,2002H,2003H,int a
2、=0;,a的内存单元,a的地址&a,如果有一变量p,其内容存放了a的地址&a,通过p也可实现对a的访问,p称为指针,并指向a。,00H,20H,0,0,p,指针的说明,指针是特殊类型的变量,其内容是变量的地址。在使用前必须说明,说明某标识符是指针类型,并可指向某种类型的对象。,指针的说明格式:type*pname1,*pnamen;,标识符命名的指针变量名。,指针标志。,指针指向对象的类型。,int*p,*q;/*p、q是指向整型变量的指针。*/,float*pfValue,*pf;/*pfValue和pf是指向浮点型的指针。*/,指针对变量的引用,定义指针的目的是通过指针引用内存对象,指针的
3、引用应按如下步骤进行:,说明指针,int a=0,*p;,指针指向对象,p=,通过指针引用对象,*p=*p+2;,4.指针操作的两种运算符:,取地址运算&a表示取变量a地址的运算。,间接运算*p表示取指针p指向变量内容的运算。,int a,*p;,2000H,a,p,p=/*p指向a。*/,2000H,*p=2;,2,举例:,#include void main(void)int x,*p;x=55;p=,2000H,x,p,2000H,55,65,关于指针的说明:,指针必须指向对象后,才能引用。,int*p;*p=2;/*Error!*/,&和*为互补运算。,int a,*p;p=则:&*p
4、 p*&a a,【例5-1】,/*example 5-1 指针访问简单变量示例*/#include void main(void)int a,b,*p1,*p2;p1=,5。指针的运算,指针是特殊类型的变量,其内容是变量的地址,因此指针的运算及结果一定要符合地址逻辑。,五种算术运算,int a,b,*p1,*p2;p1=,a,2000H,b,2400H,p1,p2,2000H,2400H,p1+;/*含义指向a后的整型单元*/,2002H,2002H,p1-;/*指向a前的整型单元*/,p1+n;/*指向a后的第n个整型单元*/,p1-n;/*指向a前的第n个整型单元*/,p2-p1;/*a和
5、b之间差的单元数*/,结果200H,p n 相当于:p的实际内容 nsizeof(*p);,六种关系运算,比较两个同类型变量之间的地址关系。,p1p2;,指针赋值运算,#include void main(void)int a,b,*p1,*p2;a=2;b=3;p1=,差别,a,&a 2000H,b,&b 2400H,p1,p2,2,3,2000H,2400H,5.2 指针与数值型数组,数组是同类型的变量的集合,各元素按下标的特定顺序占据一段连续的内存,各元素的地址也连续,指针对数组元素非常方便。,指针与一维数组,通过指针引用数组元素可以分以下三个步骤:,说明指针和数组,int*p,a10;
6、,指针指向数组,p=a;/*指向数组的首地址*/p=/*指向数组的首地址*/,通过指针引用数组元素,当指针指向数组的首地址时,则下标为i的元素地址为:p+i 或a+i,引用数组元素可以有三种方法:,下标法:a i 指针法:*(p+i)数组名法:*(a+i),注意:数组名是地址常量,不能改变!,a=p;/*Error!*/,/*example 5-2 通过指针访问数组元素*/#include void main(void)double dArray10,dAvge,*dPointer;int i;dAvge=0;dPointer=dArray;/*指针指向数组*/for(i=0;i10;i+)s
7、canf(%lf,dPointer+i);/*dPointer+i为下标为i的元素地址*/dAvge+=*(dPointer+i);/*累加各个元素的值*/dAvge/=10;printf(The avgerage of array is:%lfn,dAvge);,【例5-2】有一个具有10个元素的双精度数组,通过指针求其所有元素的平均值。,/*example 5-3 通过指针求数组元素最大值及其位置*/#include void main(void)int iArray10,*ipCur;/*ipCur遍历访问数组的指针*/int*ipPos;/*ipPos最大元素地址*/int i;ipC
8、ur=iArray;/*指针指向数组*/for(i=0;i10;i+)scanf(%d,ipCur+);/*ipCur为下标为i的数组元素的地址*/ipPos=iArray;/*指向数组首地址*/*设下标为0的元素为最大值*/ipCur=iArray+1;,【例5-3】通过指针求数组的最大值及其位置。,for(i=1;i*ipPos)ipPos=ipCur;/*ipPos保存最大元素的地址*/ipCur+;/*指向下一元素*/printf(The max is%dn,*ipPos);printf(The position is%dn,ipPos-iArray);,举例:打印数组中的奇数。,#i
9、nclude void main(void)int i,a 10;for(i=0;i10;i+)scanf(“%d”,数组元素法。,循环输入。,循环判断,满足条件输出。,数组名法。,a+i,*(a+i),指针法。,*p;,p=a;,p+,*(p+i),结果是否正确?,p=a;*p=*,注意指针在运算时的变化。,2.指针与二维数组,如下说明数组int a34=1,2,3,4,5,6,7,8,9,10,11,12;,其二维结构如下:,行,列,为了便于索引,C语言将数组分为两级管理。,a0,a1,a2,将a理解为一维数组,数组有三个元素,它们分别为a0、a1,a2。各个元素又是一个有四个元素的一维数
10、组。,从地址的角度看:a 为a0 第一行的首地址a+1 为a1 第二行的首地址a+2 为a2 第三行的首地址,a+1 地址一次加一行。,i行j列数组元素的地址可以由a i+j得到。,数组名地址的两级管理,a,a0,a1,a2,a00 a01 a02 a03,a10 a11 a12 a13,a20 a21 a22 a23,等价地址及其管理方式,数组名是数组的地址,而且是常量,*运算不改变其值!,以下三种地址等价:,a+i,*(a+i),a i,加法按行递增,加法按列递增,(a+1)+1,*(a+1)+1,差别?,数组名表示数组元素,a i j,(*(a+i)j,*(*(a+i)+j),*(a i
11、+j),指针与二维数组,int*p,a34;p=a;aij*(p+4*i+j)等价!,a00,a,a01,a02,a0,a10,a11,a12,a1,a20,a21,a22,a2,a+1,a1+2,/*example 5-4 求二维数组最小值及其位置*/#include void main(void)int a34,i,j;int iMinRow,iMinCol;/*iMinRow最小值的行,iMinCol最小值的列*/for(i=0;i3;i+)for(j=0;j4;j+)scanf(%d,ai+j);/*ai+j为i行j列元素的地址*/iMinRow=0;iMinCol=0;/*假定a00
12、为最小值*/for(i=0;i3;i+)for(j=0;j4;j+)if(*(*(a+i)+j)aiMinRowiMinCol)iMinRow=i;iMinCol=j;/*修正i和j为新的最小值下标*/printf(The min is a%d%d=%dn,iMinRow,iMinCol,aiMinRowiMinCol);,【例5-4】输入三行四列的整型数组,求最小值及其位置。,/*example 5-5 通过指针求二维数组元素的累加和*/#include void main(void)int i,j,a23,sum;int*p;p=(int*)a;/*p指向数组a,由于a加1加1行,转换为整
13、型指针*/for(i=0;i2;i+)for(j=0;j3;j+)scanf(“%d”,ai+j);/*ai+j为i行j列元素的地址*/sum=0;for(i=0;i2;i+)for(j=0;j3;j+)sum+=*(p+i*3+j);/*通过指针p表示aij*/printf(The sum of a=%dn,sum);,【例5-5】输入两行三列的整型数组,通过指针求所有元素的累加和。,举例:在数组a中查找输入的数,输出行列位置。,#include void main(void)int a34=1,2,3,4,5,6,7,8,9,10,11,12;int i,j,iS;int*p;p=a;sc
14、anf(“%d”,下标法。,*(a i+j),*(*(a+i)+j),*(p+4*i+j),【例5-6】输入3行4列的浮点型数组,通过指针求数组的平均值。,/*example 5-6 通过指针求二维数组的平均值*/#include void main(void)int i,j;float a34,fAvg;float(*p)4;p=a;/*指针指向数组*/fAvg=0;for(i=0;i3;i+)for(j=0;j4;j+)scanf(“%f”,pi+j);/*pi+j为i行j列元素的地址*/fAvg+=pij;/*pij表示aij*/fAvg/=12;printf(The average o
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C语言程序设计 语言程序设计 指针
链接地址:https://www.31ppt.com/p-6525800.html