彻底了解指针数组,数组指针,以及函数指针,以及堆中的分配规则.doc彻底了解指针数组,数组指针,以及函数指针,以及堆中的分配规则.doc

收藏 分享

资源预览需要最新版本的Flash Player支持。
您尚未安装或版本过低,建议您

彻底了解指针数组,数组指针,以及函数指针,以及堆中的分配规则一关于指针和堆的内存分配先来介绍一下指针指针一种类型,理论上来说它包含其他变量的地址,因此有的书上也叫它地址变量。既然指针是一个类型,是类型就有大小,在达内的服务器上或者普通的PC机上,都是4个字节大小,里边只是存储了一个变量的地址而已。不管什么类型的指针,CHAR,INT,INT,STRING,FLOAT,都是说明了本指针所指向的地址空间是什么类型而已,了解了这个基本上所有的问题都好象都变的合理了。在C中,申请和释放堆中分配的存贮空间,分别使用NEW和DELETE的两个运算符来完成指针类型指针变量名NEW指针类型初始化;DELETE指针名;例如1、INTPNEWINT0;它与下列代码序列大体等价2、INTTMP0,PTMP;区别P所指向的变量是由库操作符NEW分配的,位于内存的堆区中,并且该对象未命名。下面是关于NEW操作的说明部分引自C面向对象开发1、NEW运算符返回的是一个指向所分配类型变量(对象)的指针。对所创建的变量或对象,都是通过该指针来间接操作的,而动态创建的对象本身没有名字。2、一般定义变量和对象时要用标识符命名,称命名对象,而动态的称无名对象请注意与栈区中的临时对象的区别,两者完全不同生命期不同,操作方法不同,临时变量对程序员是透明的。3、堆区是不会在分配时做自动初始化的(包括清零),所以必须用初始化式INITIALIZER来显式初始化。NEW表达式的操作序列如下从堆区分配对象,然后用括号中的值初始化该对象。下面是从堆中申请数组1、申请数组空间指针变量名NEW类型名下标表达式;注意“下标表达式”不是常量表达式,即它的值不必在编译时确定,可以在运行时确定。这就是堆的一个非常显著的特点,有的时候程序员本身都不知道要申请能够多少内存的时候,堆就变的格外有用。2、释放数组空间DELETE指向该数组的指针变量名;注意方括号非常重要的,如果DELETE语句中少了方括号,因编译器认为该指针是指向数组第一个元素的,会产生回收不彻底的问题(只回收了第一个元素所占空间),我们通常叫它“内存泄露”,加了方括号后就转化为指向数组的指针,回收整个数组。DELETE的方括号中不需要填数组元素数,系统自知。即使写了,编译器也忽略。THINKINC上说过以前的DELETE方括号中是必须添加个数的,后来由于很容易出错,所以后来的版本就改进了这个缺陷。二、以下具体介绍指针指针INTA10;INTPA;指针的指针INTB20;INTPB;INTP2PP;特别注意本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系简单数组INTC10;//整数数组,含有10个整数元素也就是说每一个元素都是整数指针数组INTP10;//指针数组,含有10个指针元素也就是说每一个元素都是指针数组指针INTP10;//数组指针,这个指针能够用来指向含有10个元素的整数数组函数指针INTP;//指向函数的指针这里声明了一个指针P,该指针指向返回值是整型(即函数类型为整型)的函数指针函数INTPINTA,FLOATB;//返回值为指针的函数该函数返回指向整型变量的指针即该函数的类型为INT,P和上例不同,他是函数名上例中是指针函数存放在内存的代码区域内,他们同样有地址,我们如何能获得函数的地址呢假如我们有一个INTTESTINTA的函数,那么,他的地址就是函数的名字,这一点如同数组相同,数组的名字就是数组的起始地址。定义一个指向函数的指针用如下的形式,以上面的TEST为例INTFPINTA;//这里就定义了一个指向函数的指针函数指针不能绝对不能指向不同类型,或是带不同形参的函数,在定义函数指针的时候我们很容易犯如下的错误。INTFPINTA;//这里是错误的,因为按照结合性和优先级来看就是先和结合,然后变成了一个返回整形指针的函数了,而不是函数指针,这一点尤其需要注意下面我们来看一个具体的例子INCLUDEIOSTREAMINCLUDESTRINGUSINGNAMESPACESTD;INTTESTINTA;VOIDMAININTARGC,CHARARGV{COUTTESTENDL;//显示函数地址INTFPINTA;FPTEST;//将函数TEST的地址赋给函数学指针FPCOUTFP5|FP10ENDL;//上面的输出FP5,这是标准C的写法,FP10这是兼容C语言的标准写法,两种同意,但注意区分,避免写的程式产生移植性问题CINGET;}INTTESTINTA{RETURNA;}函数指针同样是能够作为参数传递给函数的,下面我们看个例子,仔细阅读您将会发现他的用处,稍加推理能够很方便我们进行一些复杂的编程工作。根据专家观察,这样的理论和现象都是值得各位站长深思的,所以希望大家多做研究学习,争取总结出更多更好的经验//该例以上一个例子作为基础稍加了修改INCLUDEIOSTREAMINCLUDESTRINGUSINGNAMESPACESTD;INTTESTINT;INTTEST2INTRAINT,INT;VOIDMAININTARGC,CHARARGV{COUTTESTENDL;TYPEDEFINTFPINT;FPFPI;FPITEST;//FPI赋予TEST函数的内存地址COUTTEST2FPI,1ENDL;//这里调用TEST2函数的时候,这里把FPI所存储的函数地址TEST的函数地址传递了给TEST2的第一个形参CINGET;}INTTESTINTA{RETURNA1;}INTTEST2INTRAINT,INTB//这里定义了一个名字为RA的函数指针{INTCRA10B;//在调用之后,RA已指向FPI所指向的函数地址即TEST函数RETURNC;}。利用函数指针,我们能够构成指针数组,更明确点的说法是构成指向函数的指针数组,这么说可能就容易理解的多了。INCLUDEIOSTREAMINCLUDESTRINGUSINGNAMESPACESTD;VOIDT1{COUTTEST1;}VOIDT2{COUTTEST2;}VOIDT3{COUTTEST3;}VOIDMAININTARGC,CHARARGV{VOIDA{T1,T2,T3};COUT比较T1的内存地址和数组A0所存储的地址是否一致T1|A0ENDL;COUTA0;//错误指针数组是不能利用数组下标操作调用函数的TYPEDEFVOIDFP;//自定义一个函数指针类型FPB{T1,T2,T3};//利用自定义类型FP把B定义趁一个指向函数的指针数组B0;//现在利用指向函数的指针数组进行下标操作就能够进行函数的间接调用了;CINGET;}上面的这一小段中的错误行,为什么不能这么调用呢前一篇教程我们已说的很清楚了,但是在这里我们还是复习一下概念,指针数组元素所保存的只是个内存地址,既然只是个内存地址就不可能进行A0这样地址带括号的操作,而函数指针不同他是个例外,函数指针只所以这么叫他就是因为他是指向函数指向内存的代码区的指针,他被系统授予允许和括号操作的权利,进行间接的函数调用,既然函数指针允许这么操作,那么被定义成函数指针的数组就一定是能够相同的操作的。仔细看上面的例子可能不用我多说大家也会知道是怎么一会事情了,最后我们做一个重点小结,只要记住这一点,对于理解利用函数指针构成数组进行函数间接调用就很容易了VOIDA{T1,T2,T3};COUT比较T1的内存地址和数组A0所存储的地址是否一致T1|A0ENDL;COUTA0;//错误指针数组是不能利用数组下标操作调用函数的
编号:201311211206379083    类型:共享资源    大小:39.00KB    格式:DOC    上传时间:2013-11-21
  
6
关 键 词:
专业文献 学术论文 精品文档 彻底了解
  人人文库网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
关于本文
本文标题:彻底了解指针数组,数组指针,以及函数指针,以及堆中的分配规则.doc
链接地址:http://www.renrendoc.com/p-109083.html

当前资源信息

4.0
 
(2人评价)
浏览:20次
liyun上传于2013-11-21

官方联系方式

客服手机:17625900360   
2:不支持迅雷下载,请使用浏览器下载   
3:不支持QQ浏览器下载,请用其他浏览器   
4:下载后的文档和图纸-无水印   
5:文档经过压缩,下载后原文更清晰   

精品推荐

相关阅读

人人文库
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服客服 - 联系我们

网站客服QQ:2846424093    人人文库上传用户QQ群:460291265   

[email protected] 2016-2018  renrendoc.com 网站版权所有   南天在线技术支持

经营许可证编号:苏ICP备12009002号-5