指针4指针数组多级指针动态指针.ppt
1,数组指针以此类推,一维数组名是“列指针类型”-“元素指针类型”指针变量的定义:int*p;二维数组名是“行指针类型”指针变量的定义:int(*p)4;三维数组名是“页指针类型”指针变量的定义:int(*p)34;四维数组名是“块指针类型”指针变量的定义:int(*p)345;,圆括号是必须的,2,问题的提出,变量是用于存放单个数据的数组是用于存放“同类型”的多个数据的方便循环控制结构的编程指针变量是用于存放单个地址号的“同类型”的多个地址号是否能够集中存储在一起构成“指针数组”呢?,3,元素均为指针类型数据的数组,称为指针数组 定义形式为:类型关键字*数组名数组长度;例如 char*pStr5;,四、指针数组,注意没有 圆括号,4,例:二维字符数组,void main()int i;char str10=Pascal,Basic,Fortran,Java,Visual C;for(i=0;i5;i+)printf(%sn,stri);,str,str0,Pascal,str1,str2,str3,Basic,Fortran,Java,二维数组,Visual C,str4,5,例:字符指针数组,void main()int i;char*ptr=Pascal,Basic,Fortran,Java,Visual C;for(i=0;i5;i+)printf(%sn,ptri);,6,例:字符串按字典顺序排序二维数组编程,char strN10=Pascal,Basic,Fortran,Java,Visual C;for(i=0;iN-1;i+)for(j=i+1;jN;j+)if(strcmp(strj,stri)0)strcpy(temp,stri);strcpy(stri,strj);strcpy(strj,temp);,str,str,str,str,str,7,例:字符串按字典顺序排序指针数组编程,char*ptrN=Pascal,Basic,Fortran,Java,Visual C;for(i=0;iN-1;i+)for(j=i+1;jN;j+)if(strcmp(ptrj,ptri)0)temp=ptri;ptri=ptrj;ptrj=temp;,8,命令行参数,main()函数既可以是无参函数,也可以是有参的函数.向其传递参数,只能由程序之外传递而来.main(int argc,char*argv)当你把main函数写成这样时argc的值为程序执行时参数的数目(包括命令本身)argvi为指向第i个参数的字符指针这两个内设形参用于接收命令行参数,通过命令行参数,使用户可以根据需要来决定我们的程序干什么、怎么干,9,例:演示命令行参数与main函数各形参之间的关系,void main(int argc,char*argv)int i;printf(The program name is:%sn,argv0);if(argc 1)printf(The other arguments are following:n);for(i=1;iargc;i+)printf(%sn,argvi);getch();,10,指针型函数,一个函数可以返回一个int型、float型、char型的数据,也可以返回一个指针类型的数据,即地址。返回指针值的函数(简称指针函数)的定义格式如下:函数类型*函数名(参数表)例 int*f(int x,int y),11,例 求一维数组的最大值及其下标,int*findMax(int x)int i,j;j=0;for(i=1;ixj)j=i;return(,12,五、多级指针和动态指针,1.概念及定义,定义:指向指针的指针一级指针:指针变量中存放目标变量的地址,例 int*p1;int*p2;int i=3;p2=,二级指针:指针变量中存放一级指针变量的地址,例 int*p;int i=3;p=,一级指针,二级指针,一级指针,目标变量,13,(1)定义形式:数据类型*指针名;如 int*p,i=5,*pp;(2)赋值 p=(3)引用方法pp的值*pp的值*pp的值,多级指针定义形式,14,动态分配内存,15,2.动态指针为什么要动态分配内存?当事先不知道所需要处理的数据有多大时,使用静态数组,若数组开辟得太大,则浪费内存资源(甚至可能不成功);若开辟得太小,又不能满足计算需要。采用动态分配内存的方法,使用完毕,再释放内存,以备其它程序使用。C语言中提供了几个标准函数,以实现内存的分配和释放。,16,动态分配内存,#include#include void*malloc(unsigned int size);向系统申请大小为size的内存块,把首地址返回。如果申请不成功,返回NULLvoid*calloc(unsigned int num,unsigned int size);向系统申请num个size大小的内存块,把首地址返回。如果申请不成功,返回NULLvoid free(void*p);释放由malloc()和calloc()申请的内存块。p是指向此块的指针void*类型的指针可以指向任意类型的变量,17,动态数组,一维动态数组 int*p=NULL;printf(Please enter array size:);scanf(%d,/像使用一维数组一样使用,18,函数指针(选学),1.函数指针的概念 一个函数在编译时,被分配了一个入口地址,这个地址就称为该函数的指针。可以用一个指针变量指向一个函数,然后通过该指针变量调用此函数,19,2.指向函数的指针变量(1)定义格式 函数类型(*指针变量)();注意:“*指针变量”外的括号不能缺,否则成了返回指针值的函数。例如,int(*fp)();/*fp为指向int函数的指针变量*/(2)赋值 函数名代表该函数的入口地址。因此,可用函数名给指向函数的指针变量赋值。指向函数的指针变量 注意:函数名后不能带括号和参数;函数名前的“&”符号是可选的。,20,(3)调用格式(*函数指针变量)(实参表)3.指向函数的指针变量作函数参数 指向函数的指针变量的常用用途之一,就是将函数指针作参数,传递到其它函数。函数名作实参时,因为要缺省括号和参数,造成编译器无法判断它是一个变量还是一个函数,所以必须加以函数说明。注意:对指向函数的指针变量,诸如p+i、p+/p-等运算是没有意义的。,21,函数指针应用举例,查找第1个与给定的参数 e满足“相关条件”的数据元素序号;若表中没有符合该条件的元素,返回0;否则,返回序号。int Locate(int*L,int n,int e,int(*f)(int,int)int i;for(i=0;in;i+)if(f(Li,e)return i+1;return 0;,int dengyu(int x,int y)return x=y;int dayu(int x,int y)return xy;int xiaoyu(int x,int y)return xy;/*条件:大于给定值,并能被2整除的*/,int main()int a9=1,2,3,4,5,6,7,8,9;int x;int(*fun)(int,int);fun=xiaoyu;x=Locate(a,9,6,fun);printf(Locate:%dn,x);return 1;,23,指针的概念指针是一种特殊的数据类型指针的使用原则永远要清楚指针变量存放的是什么,指向了什么 指针与数组之间的关系理解一维数组与指针是理解二维数组与指针的基础掌握二维数组在内存中的存放方式,是理解二维数组的行指针和列指针的关键指针数组指针函数指针的应用做函数参数,传地址调用动态分配内存,实现动态数组,对于动态分配的内存,不要忘记在不使用时释放,请自己总结这章所学内容,