收藏 分享(赏)

指针(4)_指针数组、多级指针、动态指针.ppt

上传人:gnk289057 文档编号:8648251 上传时间:2019-07-07 格式:PPT 页数:23 大小:449.50KB
下载 相关 举报
指针(4)_指针数组、多级指针、动态指针.ppt_第1页
第1页 / 共23页
指针(4)_指针数组、多级指针、动态指针.ppt_第2页
第2页 / 共23页
指针(4)_指针数组、多级指针、动态指针.ppt_第3页
第3页 / 共23页
指针(4)_指针数组、多级指针、动态指针.ppt_第4页
第4页 / 共23页
指针(4)_指针数组、多级指针、动态指针.ppt_第5页
第5页 / 共23页
点击查看更多>>
资源描述

1、1,数组指针以此类推,一维数组名是“列指针类型”-“元素指针类型” 指针变量的定义:int *p; 二维数组名是“行指针类型” 指针变量的定义:int (*p)4 ; 三维数组名是“页指针类型” 指针变量的定义:int (*p)34 ; 四维数组名是“块指针类型” 指针变量的定义:int (*p)345 ;,圆括号是必须的,2,问题的提出,变量是用于存放单个数据的 数组是用于存放“同类型”的多个数据的 方便循环控制结构的编程 指针变量是用于存放单个地址号的 “同类型”的多个地址号是否能够集中存储在一起构成“指针数组”呢?,3,元素均为指针类型数据的数组,称为指针数组 定义形式为: 类型关键字

2、*数组名数组长度; 例如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“,“For

3、tran“,“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,例:字符串按字典顺序

4、排序指针数组编程,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的值为程序执行时参数的数目(包括命令本身) arg

5、vi为指向第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,指针型函数,一个函数可以返回

6、一个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;

7、 int i=3;p=,一级指针,二级指针,一级指针,目标变量,13,(1) 定义形式:数据类型 *指针名; 如 int *p, i=5,*pp; (2) 赋值p= (3)引用方法 pp的值 *pp的值 *pp的值,多级指针定义形式,14,动态分配内存,15,2.动态指针 为什么要动态分配内存?当事先不知道所需要处理的数据有多大时, 使用静态数组, 若数组开辟得太大, 则浪费内存资源(甚至可能不成功); 若开辟得太小, 又不能满足计算需要。采用动态分配内存的方法,使用完毕,再释放内存,以备其它程序使用。C语言中提供了几个标准函数,以实现内存的分配和释放。,16,动态分配内存,#include

8、#include void* malloc(unsigned int size); 向系统申请大小为size的内存块,把首地址返回。如果申请不成功,返回NULL void* calloc(unsigned int num, unsigned int size); 向系统申请num个size大小的内存块,把首地址返回。如果申请不成功,返回NULL void free(void* p); 释放由malloc()和calloc()申请的内存块。p是指向此块的指针 void*类型的指针可以指向任意类型的变量,17,动态数组,一维动态数组int *p = NULL;printf(“Please ente

9、r array size:“);scanf(“%d“, /像使用一维数组一样使用,18,函数指针(选学),1.函数指针的概念 一个函数在编译时,被分配了一个入口地址,这个地址就称为该函数的指针。 可以用一个指针变量指向一个函数,然后通过该指针变量调用此函数,19,2.指向函数的指针变量 (1)定义格式函数类型 (*指针变量)( ); 注意:“*指针变量”外的括号不能缺,否则成了返回指针值的函数。 例如,int (*fp)( ); /* fp为指向int函数的指针变量*/ (2)赋值 函数名代表该函数的入口地址。因此,可用函数 名给指向函数的指针变量赋值。 指向函数的指针变量 注意:函数名后不能

10、带括号和参数;函数名前的“&”符号是可选的。,20,(3)调用格式(*函数指针变量)(实参表) 3.指向函数的指针变量作函数参数指向函数的指针变量的常用用途之一,就是将函数指针 作参数,传递到其它函数。函数名作实参时,因为要缺省括号和参数,造成编译器 无法判断它是一个变量还是一个函数,所以必须加以函数说 明。注意:对指向函数的指针变量,诸如p+i、p+/p-等运算 是没有意义的。,21,函数指针应用举例,查找第1个与给定的参数 e满足“相关条件”的数据元素序号;若表中没有符合该条件的元素,返回0;否则,返回序号。int Locate(int *L,int n,int e,int (*f)(in

11、t,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,指针的概念 指针是一种特殊的数据类型 指针的使用原则 永远要清楚指针变量存放的是什么,指向了什么 指针与数组之间的关系 理解一维数组与指针是理解二维数组与指针的基础 掌握二维数组在内存中的存放方式,是理解二维数组的行指针和列指针的关键 指针数组 指针函数 指针的应用 做函数参数,传地址调用 动态分配内存,实现动态数组,对于动态分配的内存,不要忘记在不使用时释放,请自己总结这章所学内容,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报