九章指针.ppt
《九章指针.ppt》由会员分享,可在线阅读,更多相关《九章指针.ppt(77页珍藏版)》请在三一办公上搜索。
1、第九章 指针,C程序设计中使用指针可以:使程序简洁、紧凑、高效有效地表示复杂的数据结构动态分配内存得到多于一个的函数返回值,9.1 指针的概念变量与地址,程序中:int i;float k;,内存中每个字节有一个编号-地址,i,k,编译或函数调用时为其分配内存单元,变量是对程序中数据存储空间的抽象,指针变量:专门存放变量地址的变量叫,2000,指针,指针变量,变量的内容,变量的地址,地址:内存中每一个字节有一个编号指针:可根据变量地址找到变量的存储单元,地址起到指示性作用,一个变量的地址称为该变量的指针,&与*运算符含义,含义:取变量的地址单目运算符优先级:2结合性:自右向左,含义:取指针所指
2、向变量的内容单目运算符优先级:2结合性:自右向左,两者关系:互为逆运算理解,i_pointer-指针变量,它的内容是地址量*i_pointer-指针的目标变量,它的内容是数据&i_pointer-指针变量占用内存的地址,i_pointer&i&(*i_pointer)i*i_pointer*(&i),i_pointer=&i=&(*i_pointer)i=*i_pointer=*(&i),在C程序中用*表示指向例:i_pointer为指针变量,则*i_pointer是i_pointer所指向的变量,*i_pointer,i*i_pointer,指针变量与其所指向的变量之间的关系,&i,i_po
3、inter,i=3;,*i_pointer=3;,直接访问与间接访问直接访问:按变量地址存取变量值间接访问:通过存放变量地址的变量去访问变量,i=3;-直接访问,3,*i_pointer=20;-间接访问,20,k=i;-直接访问 k=*i_pointer;-间接访问,10,k=i;k=*i_pointer;,9.2 变量与指针指针变量与其所指向的变量之间的关系,指针变量的定义一般形式:存储类型 数据类型*指针名;,合法标识符,指针变量本身的存储类型,指针的目标变量的数据类型,表示定义指针变量不是*运算符,int*p1,*p2;float*q;static char*name;,注意:1、in
4、t*p1,*p2;与 int*p1,p2;2、指针变量名是p1,p2,不是*p1,*p23、指针变量只能指向定义时所规定类型的变量4、指针变量定义后,变量值不确定,应用前必须先赋值,指针变量的初始化一般形式:存储类型 数据类型*指针名=初始地址值;,赋给指针变量,不是赋给目标变量,int i;int*p=,变量必须与已说明过的类型应一致,int i;int*p=,用已初始化指针变量作初值,main()int i;static int*p=.(),不能用auto变量的地址去初始化static型指针,main()int i=10;int*p;*p=i;printf(“%d”,*p);,危险!,ma
5、in()int i=10,k;int*p;p=,指针变量必须先赋值,再使用,零指针与空类型指针零指针:(空指针)定义:指针变量值为零表示:int*p=0;,p指向地址为0的单元,这意味着,指针并不指向任何地址。,#define NULL 0int*p=NULL:,p=NULL与未对p赋值不同用途:避免指针变量的非法引用在程序中常作为状态比较,int*p;.while(p!=NULL).,void*类型指针表示:void*p;使用时要进行强制类型转换,char*p1;void*p2;p1=(char*)p2;p2=(void*)p1;,表示不指定p是指向哪一种类型数据的指针变量,指针的概念,ma
6、in()int a;int*pa=,运行结果:a:10*pa:10&a:f86(hex)pa:f86(hex)&pa:f88(hex),输入两个数,并使其从大到小输出,main()int*p1,*p2,*p,a,b;scanf(%d,%d,运行结果:a=5,b=9 max=9,min=5,5,2006,9,2008,2006,2008,2006,指针变量作为函数参数地址传递特点:共享内存,“双向”传递,swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;scanf(%d,%d,将数从大到小输出,5,9,5,5,9,COPY,指针变
7、量作为函数参数地址传递特点:共享内存,“双向”传递,swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;scanf(%d,%d,将数从大到小输出,值传递,5,9,运行结果:5,9,swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;a=5;b=9;if(ab)swap(a,b);printf(n%d,%dn,a,b);,交互两数。,5,9,a,b,x,y,5,9,5,9,temp,形参、实参是简单变量时,单向值传递,也可以这样描述:,swap(int*q1,int*q
8、2)int q;q=*q1;*q1=*q2;*q2=q;main()int a,b;int*p1,*p2;a=5;b=9;p1=,交换两数。,5,9,a,b,&b,&a,p1,p2,q1,q2,q,5,9,5,形参、实参是指针变量时,实现“双向”传递,实参本身没有改变,改变的是实参所指向的对象,地址传递,运行结果:9,5,&b,&a,swap(int*q1,int*q2)int*q;q=q1;q1=q2;q2=q;main()int a,b;int*p1,*2;a=5;b=9;p1=,交换两数。,运行结果:5,9,5,9,a,b,&b,&a,p1,p2,q1,q2,q,&a,改变的是形参本身,
9、并不能影响实参,当然也不能影响实参所指向的对象,&b,&a,&b,&a,swap(int*q1,int*q2)int*q;*q=*q1;*q1=*q2;*q2=*q;main()int a,b;int*p1,*2;a=5;b=9;p1=,交换两数。,运行结果:9,5,5,9,a,b,&b,&a,p1,p2,q1,q2,q,但是,指针q未赋值,就取*运算,*q=.,9,5,危险,main()int a,b;int*p1,*p2;a=5;b=9;p1=,(1)swap(int*q1,int*q2)int*q;q=q1;q1=q2;q2=q;,(2)swap(int*q1,int*q2)int*q;
10、*q=*q1;*q1=*q2;*q2=*q;,(3)swap(int*q1,int*q2)int q;q=*q1;*q1=*q2;*q2=q;,或者更改:int k,*q=,9.3 一维数组与指针指向数组元素的指针变量,例 int array10;int*p;p=,数组名是表示数组首地址的地址常量,指针的运算指针变量的赋值运算p=(指针变量p2值p1)不能把一个整数p,也不能把p的值整型变量,如 int i,*p;p=1000;()i=p;(),指针变量与其指向的变量具有相同数据类型,指针的算术运算:pi p id(i为整型数,d为p指向的变量所占字节数)p+,p-,p+i,p-i,p+=i,
11、p-=i等若p1与p2指向同一数组,p1-p2=两指针间元素个数(p1-p2)/dp1+p2 无意义,p指向float数,则 p+1 p+1 4,p指向int型数组,且p=则p+1 指向a1,int a10;int*p=,int a10;int*p1=则:p2-p1=?,1,指针的运算指针变量的赋值运算,3,指针变量的关系运算若p1和p2指向同一数组,则p1p2 表示p1指的元素在后p1=p2 表示p1与p2指向同一元素若p1与p2不指向同一数组,比较无意义p=NULL或p!=NULL,指针的运算指针变量的赋值运算指针的算术运算,数组元素表示方法,变址运算符ai*(a+i),ai pi*(p+
12、i)*(a+i),数组元素的引用方法,main()int a5,*pa,i;for(i=0;i5;i+)ai=i+1;pa=a;for(i=0;i5;i+)printf(*(pa+%d):%dn,i,*(pa+i);for(i=0;i5;i+)printf(*(a+%d):%dn,i,*(a+i);for(i=0;i5;i+)printf(pa%d:%dn,i,pai);for(i=0;i5;i+)printf(a%d:%dn,i,ai);,int a=1,2,3,4,5,6,7,8,9,10,*p=a,i;数组元素地址的正确表示:(A)&(a+1)(B)a+(C)&p(D)&pi,数组名是地
13、址常量p+,p-()a+,a-()a+1,*(a+2)(),例 void main()int a=5,8,7,6,2,7,3;int y,*p=,输出:5 6,注意指针变量的运算,6,main()int i,*p,a7;p=a;for(i=0;i7;i+)scanf(%d,p+);printf(n);for(i=0;i7;i+,p+)printf(%d,*p);,注意指针的当前值,p=a;,指针变量可以指到数组后的内存单元,数组名作函数参数数组名作函数参数,是地址传递数组名作函数参数,实参与形参的对应关系,void convert(int x,int n)int t,i=0,j=n-1;for
14、(i=0;ij;i+,j-)t=xi;xi=xj;xj=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2;convert(a,10);printf(reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);,将数组a中的n个整数按相反顺序存放,实参与形参均用数组,a,x,将数组a中的n个整数按相反顺序存放,void convert(int*p,int n)int t,*q;for(q=p+n-1;pq;p+,q-)t=*p;*p=*q;*q=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2;co
15、nvert(a,10);printf(reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);,实参用数组,形参用指针变量,pq;,将数组a中的n个整数按相反顺序存放,void convert(int*p,int n)int t,*q;for(q=p+n-1;pq;p+,q-)t=*p;*p=*q;*q=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2,*pa=a;convert(pa,10);printf(reverted:n);for(i=0;i10;i+)printf(%d,*(pa+i);printf(n);,实
16、参与形参均用指针变量,for(i=0;i10;i+)printf(“%d”,*pa+);,for(i=0;i10;i+,pa+)printf(“%d”,*pa);,for(;paa+10;pa+)printf(“%d”,*pa);,一级指针变量与一维数组的关系int*p 与 int q10 数组名是指针(地址)常量p=q;p+i 是qi的地址数组元素的表示方法:下标法和指针法,即若p=q,则 pi qi*(p+i)*(q+i)形参数组实质上是指针变量,即int q int*q在定义指针变量(不是形参)时,不能把int*p 写成int p;系统只给p分配能保存一个指针值的内存区(一般2字节);而
17、给q分配2*10字节的内存区,9.4 多维数组与指针,对于一维数组:(1)数组名array表示数组的首地址,即array0的地址;(2)数组名array是地址常量(3)array+i是元素arrayi的地址(4)arrayi*(array+i),二维数组理解,int a34;,每个元素ai由包含4个元素的一维数组组成,二维数组a是由3个元素组成,对于二维数组:(1)a是数组名,包含三个元素 a0,a1,a2(2)每个元素ai 又是一个一维 数组,包含4个 元素,int a34;,基类型,行指针与列指针,对二维数组 int a34,有a-二维数组的首地址,即第0行的首地址a+i-第i行的首地址a
18、i*(a+i)-第i行第0列的元素地址ai+j*(a+i)+j-第i行第j列的元素地址*(ai+j)*(*(a+i)+j)aij,a+i=&ai=ai=*(a+i)=&ai0,值相等,含义不同a+i&ai,表示第i行首地址,指向行ai*(a+i)&ai0,表示第i行第0列元素地址,指向列,二维数组元素表示形式:(1)a12(2)*(a1+2)(3)*(*(a+1)+2)(4)*(&a00+1*4+2),地址表示:(1)a+1(2)&a10(3)a1(4)*(a+1)(5)(int*)(a+1),地址表示:(1)&a12(2)a1+2(3)*(a+1)+2(4)&a00+1*4+2,二维数组的指
19、针变量指向二维数组元素的指针变量列指针变量,指向二维数组元素的列指针变量,main()int a34=1,3,5,7,9,11,13,15,17,19,21,23;int*p;for(p=a0;pa0+12;p+)if(p-a0)%4=0)printf(n);printf(%4d,*p);,p=*a;p=,指向一维数组的指针变量行指针变量定义形式:数据类型(*指针名)一维数组维数;例 int(*p)4;,()不能少int(*p)4与int*p4不同,p的值是一维数组的首地址,p是行指针,可让p指向二维数组某一行 如 int a34,(*p)4=a;,一维数组指针变量维数和二维数组列数应该相同,
20、二维数组的指针变量指向二维数组元素的指针变量列指针变量,行指针变量举例,main()static int a34=1,3,5,7,9,11,13,15,17,19,21,23;int i,j,(*p)4;for(p=a,i=0;i3;i+,p+)for(j=0;j4;j+)printf(%d,*(*p+j);printf(n);,p=a0;p=*a;p=,p0j,二维数组与指针运算,main()int a34=1,2,3,4,3,4,5,6,5,6,7,8;int i;int(*p)4=a,*q=a0;for(i=0;i3;i+)if(i=0)(*p)i+i/2=*q+1;else p+,+q



- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 指针

链接地址:https://www.31ppt.com/p-5308946.html