《高级语言程序设计(c)10指针.ppt》由会员分享,可在线阅读,更多相关《高级语言程序设计(c)10指针.ppt(44页珍藏版)》请在三一办公上搜索。
1、指针,梁春燕华电信息管理教研室,主要内容,指针的概念指针变量指针与数组上机作业,指针的概念,C程序设计中使用指针可以:使程序简洁、紧凑、高效有效地表示复杂的数据结构动态分配内存得到多于一个的函数返回值,指针的概念,变量与地址,程序中: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),&与*运算符,直接访问:按变量地址存取变量值间接访问:通过存放变量地址的变量去访问变量,例 i=3;-直接访问,3,例*i_pointer=20;-间接访问,20,直接访问与间接访问,例 k=i;-直接访问 k=*i_poin
3、ter;-间接访问,10,例 k=i;k=*i_pointer;,例子图解,指针变量,指针变量与其所指向的变量之间的关系,指针变量的定义一般形式:存储类型 数据类型*指针名;,合法标识符,指针变量本身的存储类型,指针的目标变量的数据类型,表示定义指针变量不是*运算符,例 int*p1,*p2;float*q;static char*name;,注意:1、int*p1,*p2;与 int*p1,p2;2、指针变量名是p1,p2,不是*p1,*p23、指针变量只能指向定义时所规定类型的变量4、指针变量定义后,变量值不确定,应用前必须先赋值,指针变量,一般形式:存储类型 数据类型*指针名=初始地址值
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);,危险!,例 main()int i=10,k;int*p;p=,指针变量必须先赋值,再使用,零指针:(空指针)定义:指针变量值为零表示:int*p=NULL;,p指向地址为0的单元,系统保证该单元不作它用表示指针变量值没有意义,
5、#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是指向哪一种类型数据的指针变量,零指针与空类型指针,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,例 输入两个数,并使
6、其从大到小输出,特点:共享内存,“双向”传递,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,指针变量作为函数参数地址传递,5,9,运行结果:5,9,特点:共享内存,“双向”传递,swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;scanf(%d,%d,例 将数从大到小输出,指针变量作为函数参数地址传递,值传递,swap(int*p1,int*p2)int p;p=*p1;*p1=*p2
7、;*p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,5,9,2000,2002,5,9,COPY,5,例 将数从大到小输出,5,9,2000,2002,5,9,运行结果:9,5,地址传递,swap(int*p1,int*p2)int p;p=*p1;*p1=*p2;*p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,例 将数从大到小输出,swap(int*p1,int*p2)int*p;*p=*p1;*p1=*p2;*p2=*p;main()int a,b;int*po
8、inter_1,*pointer_2;scanf(%d,%d,运行结果:9,9,编译警告!结果不对!,int x;int*p=,5,9,2000,2002,9,9,COPY,假设2000,指针变量在使用前必须赋值!,例 将数从大到小输出(2),swap(int x,int y)int t;t=x;x=y;y=t;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,运行结果:5,9,值传递,5,9,2000,2002,COPY,5,5,9,例 将数从大到小输出(3),运行结果:5,9,swap(int*p1,int*p2)int*p;p=p1;p
9、1=p2;p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,5,9,2000,2002,COPY,2000,地址传递,2000,2002,例 将数从大到小输出(4),指针与数组,指向数组元素的指针变量,例 int array10;int*p;p=,数组名是表示数组首地址的地址常量,指针与数组,指针变量的赋值运算p=(指针变量p2值p1)不能把一个整数p,也不能把p的值整型变量,如 int i,*p;p=1000;()i=p;(),指针变量与其指向的变量具有相同数据类型,指针的运算,pi p id(i为整型数,d为p指向的变量所占字节
10、数)p+,p-,p+i,p-i,p+=i,p-=i等 若p1与p2指向同一数组,p1-p2=两指针间元素个数(p1-p2)/d p1+p2 无意义,例 p指向float数,则 p+1 p+1 4,例 p指向int型数组,且p=则p+1 指向a1,例 int a10;int*p=,例 int a10;int*p1=,1,指针的算术运算:,若p1和p2指向同一数组,则p1p2 表示p1指的元素在后p1=p2 表示p1与p2指向同一元素 若p1与p2不指向同一数组,比较无意义 p=NULL或p!=NULL,指针变量的关系运算,下标运算符ai*(a+i),ai pi*(p+i)*(a+i),main(
11、)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,数组名是地址常量p+,p-()
12、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 inv(int x,int n)int t,i,j,m=(n-1)
13、/2;for(i=0;i=m;i+)j=n-1-i;t=xi;xi=xj;xj=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2;inv(a,10);printf(The array has been reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);,m=4,例 将数组a中的n个整数按相反顺序存放(1),void inv(int*x,int n)int t,*p,*i,*j,m=(n-1)/2;i=x;j=x+n-1;p=x+m;for(;i=p;i+,j-)t=*i;*i=*j;*j=t;main()int i
14、,a10=3,7,9,11,0,6,7,5,4,2;inv(a,10);printf(The array has been reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);,实参用数组,形参用指针变量,例 将数组a中的n个整数按相反顺序存放(2),void inv(int*x,int n)int t,*i,*j,*p,m=(n-1)/2;i=x;j=x+n-1;p=x+m;for(;i=p;i+,j-)t=*i;*i=*j;*j=t;main()int i,a10,*p=a;for(i=0;i10;i+,p+)scanf(%d,p);p=a
15、;inv(p,10);printf(The array has been reverted:n);for(p=a;pa+10;p+)printf(%d,*p);,实参与形参均用指针变量,例 将数组a中的n个整数按相反顺序存放(3),void inv(int x,int n)int t,i,j,m=(n-1)/2;for(i=0;i=m;i+)j=n-1-i;t=xi;xi=xj;xj=t;main()int i,a10,*p=a;for(i=0;i10;i+,p+)scanf(%d,p);p=a;inv(p,10);printf(The array has been reverted:n);f
16、or(p=arr;parr+10;p+)printf(%d,*p);,实参用指针变量,形参用数组,例 将数组a中的n个整数按相反顺序存放(4),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字节);而给q分配2*10字节的内存区,一级指针变量与一维数组的关系,小结,小结,指针的概念:指针和地址,指针变量:指针变量的定义、赋值和使用,指针作为函数参数;指针与数组:指针对一维数组的操作,指向一维数组的指针变量的定义和使用。,上机作业,上机作业9,试验目的理解和掌握指针的概念;掌握指针变量的定义和使用;能正确使用数组的指针和指向数组的指针变量。,上机作业9,试验内容编写两个子函数:函数transpose来实现将一个数组转置;函数max_value来求出数组中的最大元素值;在主函数main中,将含有12个元素的整型数组初始化,然后分别调用两个子函数来对数组进行转置和求最大值,最后输出已转置的数组和最大值。,END,