第六章数组指针与字符串.ppt

上传人:sccc 文档编号:6000992 上传时间:2023-09-13 格式:PPT 页数:161 大小:2.58MB
返回 下载 相关 举报
第六章数组指针与字符串.ppt_第1页
第1页 / 共161页
第六章数组指针与字符串.ppt_第2页
第2页 / 共161页
第六章数组指针与字符串.ppt_第3页
第3页 / 共161页
第六章数组指针与字符串.ppt_第4页
第4页 / 共161页
第六章数组指针与字符串.ppt_第5页
第5页 / 共161页
点击查看更多>>
资源描述

《第六章数组指针与字符串.ppt》由会员分享,可在线阅读,更多相关《第六章数组指针与字符串.ppt(161页珍藏版)》请在三一办公上搜索。

1、第六章 数组 指针与字符串,清华大学 郑 莉,目录,6.1 数组6.2 指针6.3 动态内存分配6.4 用vector创建数组对象6.5 深拷贝与浅拷贝6.6 字符串6.7 综合实例个人银行账户管理程序6.8 深度探索6.9 小结,2,数组的概念,数组是具有一定顺序关系的若干相同类型变量的集合体,组成数组的变量称为该数组的元素。数组属于构造类型。,3,6.1 数组,6.1.1 数组的声明与使用,数组的声明,4,6.1 数组,类型说明符 数组名 常量表达式 常量表达式;,例如:int a10;表示a为整型数组,有10个元素:a0.a9,例如:int a53;表示a为整型二维数组,其中第一维有5个

2、下标(04),第二维有3个下标(02),数组的元素个数为15,可以用于存放5行3列的整型数据表格。,6.1.1 数组的声明与使用(续),引用必须先声明,后使用。只能逐个引用数组元素,而不能一次引用整个数组例如:a0=a5+a7-a2*3例如:b12=a23/2,5,6.1 数组,6,6.1 数组 6.1.1 数组的声明与使用,例6-1,#include using namespace std;int main()int a10,b10;for(int i=0;i 10;i+)ai=i*2-1;b10-i-1=ai;for(int i=0;i 10;i+)cout a i=ai;cout b I

3、=bi endl;return 0;,7,6.1 数组,6.1.2 数组的存储与初始化,一维数组的存储数组元素在内存中顺次存放,它们的地址是连续的。例如:,数组名字是数组首元素的内存地址。数组名是一个常量,不能被赋值。,8,6.1 数组,6.1.2 数组的存储与初始化(续),一维数组的初始化可以在定义数组的同时赋给初值:在声明数组时对数组元素赋以初值。例如:static int a10=0,1,2,3,4,5,6,7,8,9;可以只给一部分元素赋初值。例如:static int a10=0,1,2,3,4;在对全部数组元素赋初值时,可以不指定数组长度。例如:static int a=0,1,2

4、,3,4,5,6,7,8,9,9,6.1 数组,6.1.2 数组的存储与初始化(续),二维数组的存储按行存放例如:float a34;其中数组a的存储顺序为:,a00 a01 a02 a03 a10 a11 a12 a13 a20 a21 a22 a23,10,6.1 数组,6.1.2 数组的存储与初始化(续),二维数组的初始化将所有数据写在一个内,按顺序赋值例如:static int a34=1,2,3,4,5,6,7,8,9,10,11,12;分行给二维数组赋初值例如:static int a34=1,2,3,4,5,6,7,8,9,10,11,12;可以对部分元素赋初值例如:static

5、 int a34=1,0,6,0,0,11;,11,6.1 数组 6.1.2 数组的存储与初始化,例:数组处理求Fibonacci数列,#include using namespace std;int main()int f20=1,1;/初始化第0、1个数 for(int i=2;i 20;i+)/求第219个数 fi=fi-2+fi-1;for(i=0;i20;i+)/输出,每行5个数 if(i%5=0)cout endl;cout.width(12);/设置输出宽度为12 cout fi;return 0;,12,6.1 数组 6.1.2 数组的存储与初始化,例(续),运行结果:1123

6、5813213455891442333776109871597258441816765,例:一维数组应用举例,循环从键盘读入若干组选择题答案,计算并输出每组答案的正确率,直到输入ctrl+z为止。每组连续输入5个答案,每个答案可以是a.d。,13,6.1 数组 6.1.2 数组的存储与初始化,例(续),#include using namespace std;int main()const char KEY=a,c,b,a,d;const int NUM_QUES=5;char c;int ques=0,numCorrect=0;cout(numCorrect)/NUM_QUES*100%;q

7、ues=0;numCorrect=0;cout endl;return 0;,14,6.1 数组 6.1.2 数组的存储与初始化,15,6.1 数组 6.1.2 数组的存储与初始化,例(续),运行结果:acbba*Score 60%acbad Score 100%abbda*Score 40%bdcba*Score 0%,16,6.1 数组,6.1.3 数组作为函数参数,数组元素作实参,与单个变量一样。数组名作参数,形、实参数都应是数组名,类型要一样,传送的是数组首地址。对形参数组的改变会直接影响到实参数组。,例6-2 使用数组名作为函数参数,主函数中初始化一个矩阵并将每个元素都输出,然后调用

8、子函数,分别计算每一行的元素之和,将和直接存放在每行的第一个元素中,返回主函数之后输出各行元素的和。,17,6.1 数组 6.1.3 数组作为函数参数,#include using namespace std;void rowSum(int a4,int nRow)for(int i=0;i nRow;i+)for(int j=1;j 4;j+)ai0+=aij;int main()/主函数int table34=1,2,3,4,2,3,4,5,3,4,5,6;/声明并初始化数组,18,例6-2(续),6.1 数组 6.1.3 数组作为函数参数,/输出数组元素for(int i=0;i 3;i

9、+)for(int j=0;j 4;j+)cout tableij;cout endl;rowSum(table,3);/调用子函数,计算各行和/输出计算结果for(int i=0;i 3;i+)cout Sum of row i is tablei0 endl;return 0;,19,例6-2(续),6.1 数组 6.1.3 数组作为函数参数,20,例6-2(续),运行结果:1 2 3 42 3 4 53 4 5 6Sum of row 0 is 10Sum of row 1 is 14Sum of row 2 is 18,6.1 数组 6.1.3 数组作为函数参数,21,6.1 数组,6

10、.1.4 对象数组,声明:类名 数组名元素个数;访问方法:通过下标访问 数组名下标.成员名,22,对象数组初始化,数组中每一个元素对象被创建时,系统都会调用类构造函数初始化该对象。通过初始化列表赋值。例:Point a2=Point(1,2),Point(3,4);如果没有为数组元素指定显式初始值,数组元素便使用默认值初始化(调用缺省构造函数)。,6.1 数组 6.1.4 对象数组,23,数组元素所属类的构造函数,不声明构造函数,则采用缺省构造函数。各元素对象的初值要求为相同的值时,可以声明具有默认形参值的构造函数。各元素对象的初值要求为不同的值时,需要声明带形参的构造函数。当数组中每一个对象

11、被删除时,系统都要调用一次析构函数。,6.1 数组 6.1.4 对象数组,24,例6-3 对象数组应用举例,/Point.h#ifndef _POINT_H#define _POINT_Hclass Point/类的定义public:/外部接口Point();Point(int x,int y);Point();void move(int newX,int newY);int getX()const return x;int getY()const return y;static void showCount();/静态函数成员private:/私有数据成员int x,y;#endif/_PO

12、INT_H,6.1 数组 6.1.4 对象数组,25,例6-3(续),/Point.cpp#include#include Point.husing namespace std;Point:Point()x=y=0;cout Default Constructor called.endl;Point:Point(int x,int y):x(x),y(y)cout Constructor called.endl;Point:Point()cout Destructor called.endl;void Point:move(int newX,int newY)cout Moving the p

13、oint to(newX,newY)endl;x=newX;y=newY;,6.1 数组 6.1.4 对象数组,26,例6-3(续),/6-3.cpp#include Point.h#include using namespace std;int main()cout Entering main.endl;Point a2;for(int i=0;i 2;i+)ai.move(i+10,i+20);cout Exiting main.endl;return 0;,6.1 数组 6.1.4 对象数组,27,例6-3(续),运行结果:Entering main.Default Constructo

14、r called.Default Constructor called.Moving the point to(10,20)Moving the point to(11,21)Exiting main.Destructor called.Destructor called.,6.1 数组 6.1.4 对象数组,6.1.5 程序实例,例6-4 利用Point类进行点的线性拟合用n个数据点拟合成直线的问题,直线模型为其中:,28,6.1 数组,/Point.h#ifndef _POINT_H#define _POINT_Hclass Point/Point类的定义public:/外部接口Point

15、(float x=0,float y=0):x(x),y(y)float getX()const return x;float getY()const return y;private:/私有数据成员float x,y;#endif/_POINT_H,29,6.1 数组 6.1.5 程序实例,例6-4(续),/6_4.cpp#include Point.h#include#include using namespace std;/直线线性拟合,points为各点,nPoint为点数float lineFit(const Point points,int nPoint)float avgX=0,

16、avgY=0;float lxx=0,lyy=0,lxy=0;for(int i=0;i nPoint;i+)/计算x、y的平均值avgX+=pointsi.getX()/nPoint;avgY+=pointsi.getY()/nPoint;for(int i=0;i nPoint;i+)/计算Lxx、Lyy和Lxylxx+=(pointsi.getX()-avgX)*(pointsi.getX()-avgX);lyy+=(pointsi.getY()-avgY)*(pointsi.getY()-avgY);lxy+=(pointsi.getX()-avgX)*(pointsi.getY()-

17、avgY);,30,6.1 数组 6.1.5 程序实例,例6-4(续),cout(lxy/sqrt(lxx*lyy);/返回相关系数rint main()Point p10=Point(6,10),Point(14,20),Point(26,30),Point(33,40),Point(46,50),Point(54,60),Point(67,70),Point(75,80),Point(84,90),Point(100,100);/初始化数据点float r=lineFit(p,10);/进行线性回归计算cout Line coefficient r=r endl;/输出相关系数return

18、 0;,31,6.1 数组 6.1.5 程序实例,例6-4(续),例6-4(续),运行结果为:This line can be fitted by y=ax+b.a=0.97223 b=5.90237Line coefficient r=0.998193,32,6.1 数组 6.1.5 程序实例,6.2.1 内存空间的访问方式,内存空间的访问方式通过变量名访问通过地址访问,33,6.2 指针,6.2.2 指针变量的声明,概念指针:内存地址,用于间接访问内存单元指针变量:用于存放地址的变量声明例:static int i;static int*ptr=,34,6.2 指针,指向整型变量的指针,6

19、.2.3 与地址相关的运算“*”和“&”,地址运算符:则&var 表示变量 var 在内存中的起始地址,35,6.2 指针,6.2.4 指针的赋值,指针变量的初始化语法形式存储类型 数据类型*指针名初始地址;例:int*pa=注意事项用变量地址作为初值时,该变量必须在指针初始化之前已声明过,且变量类型应与指针类型一致。可以用一个已赋初值的指针去初始化另一个指针变量。不要用一个内部 auto 变量去初始化 static 指针。,36,6.2 指针,指针变量的赋值运算,指针名=地址“地址”中存放的数据类型与指针类型必须相符。向指针变量赋的值必须是地址常量或变量,不能是普通整数。但可以赋值为整数0,

20、表示空指针。指针的类型是它所指向变量的类型,而不是指针本身数据值的类型,任何一个指针本身的数据值都是unsigned long int型。允许声明指向 void 类型的指针。该指针可以被赋予任何类型对象的地址。例:void*general;,37,6.2 指针 6.2.4 指针的赋值,例6-5 指针的声明、赋值与使用,#include using namespace std;int main()int i;/定义int型数iint*ptr=,38,6.2 指针 6.2.4 指针的赋值,运行结果:i=10*ptr=10,例6-6 void类型指针的使用,#include using namesp

21、ace std;int main()/!void voidObject;错,不能声明void类型的变量void*pv;/对,可以声明void类型的指针int i=5;pv=,39,6.2 指针 6.2.4 指针的赋值,指向常量的指针,不能通过指针来改变所指对象的值,但指针本身可以改变,可以指向另外的对象。例:int a;const int*p1=/编译时出错,不能通过p1改变所指的对象,40,6.2 指针 6.2.4 指针的赋值,指针类型的常量,若声明指针常量,则指针本身的值不能被改变。例:int a;int*const p2=/错误,p2是指针常量,值不能改变,41,6.2 指针 6.2.4

22、 指针的赋值,指针变量的算术运算,指针与整数的加减运算指针p加上或减去n,其意义是指针当前指向位置的前方或后方第n个数据的地址。这种运算的结果值取决于指针指向的数据类型。p1n1等价于*(p1+n1)指针加一,减一运算指向下一个或前一个数据。例如:y=*px+相当于 y=*(px+)(*和+优先级相同,自右向左运算),42,6.2 指针 6.2.5 指针运算,pa,43,6.2 指针 6.2.5 指针运算,pb-1,pb,pb+1,pb+2,*(pb-1)或pb-1,*pb或pb0,*(pb+1)或pb1,*(pb+2)或pb2,long*pb,44,6.2 指针 6.2.5 指针运算,指针变

23、量的关系运算,关系运算指向相同类型数据的指针之间可以进行各种关系运算。指向不同数据类型的指针,以及指针与一般整数变量之间的关系运算是无意义的。指针可以和零之间进行等于或不等于的关系运算。例如:p=0或p!=0赋值运算向指针变量赋的值必须是地址常量或变量,不能是普通整数。但可以赋值为整数0,表示空指针。,45,6.2 指针 6.2.5 指针运算,6.2.6 用指针处理数组元素,声明与赋值例:int a10,*pa;pa=通过指针引用数组元素经过上述声明及赋值后:*pa就是a0,*(pa+1)就是a1,.,*(pa+i)就是ai.ai,*(pa+i),*(a+i),pai都是等效的。不能写 a+,

24、因为a是数组首地址是常量。,46,6.2 指针,例6-7,47,6.2 指针 6.2.6 用指针处理数组元素,设有一个int型数组a,有10个元素。用三种方法输出各元素:使用数组名和下标使用数组名和指针运算使用指针变量,例6-7(续)使用数组名和下标,48,6.2 指针 6.2.6 用指针处理数组元素,#include using namespace std;int main()int a10=1,2,3,4,5,6,7,8,9,0;for(int i=0;i 10;i+)cout ai;cout endl;return 0;,例6-7(续)使用数组名指针运算,49,6.2 指针 6.2.6

25、用指针处理数组元素,#include using namespace std;int main()int a10=1,2,3,4,5,6,7,8,9,0;for(int i=0;i 10;i+)cout*(a+i);cout endl;return 0;,例6-7(续)使用指针变量,50,6.2 指针 6.2.6 用指针处理数组元素,#include using namespace std;int main()int a10=1,2,3,4,5,6,7,8,9,0;for(int*p=a;p(a+10);p+)cout*p;cout endl;return 0;,6.2.7 指针数组,数组的元

26、素是指针型例:Point*pa2;由pa0,pa1两个指针组成,51,6.2 指针,例6-8 利用指针数组存放单位矩阵,52,6.2 指针 6.2.7 指针数组,#include using namespace std;int main()int line1=1,0,0;/矩阵的第一行int line2=0,1,0;/矩阵的第二行int line3=0,0,1;/矩阵的第三行/定义整型指针数组并初始化int*pLine3=line1,line2,line3;,例6-8(续),53,6.2 指针 6.2.7 指针数组,cout Matrix test:endl;/输出单位矩阵for(int i=

27、0;i 3;i+)for(int j=0;j 3;j+)cout pLineij;cout endl;return 0;,输出结果为:Matrix test:1,0,00,1,00,0,1,例6-9 二维数组举例,54,6.2 指针 6.2.7 指针数组,#include using namespace std;int main()int array233=11,12,13,21,22,23,31,32,33;for(int i=0;i 3;i+)for(int j=0;j 3;j+)cout*(*(array2+i)+j);/逐个输出二维数组第i行元素值 cout endl;return 0

28、;,55,例6-9(续),运行结果:11 12 1321 22 2331 32 33,6.2 指针 6.2.7 指针数组,56,指针数组 vs 二维数组,6.2 指针 6.2.7 指针数组,pLine0,pLine1,pLine2,(a)指针数组,array20,array21,array22,array2,二维数组,pLine,6.2.8 用指针作为函数参数,以地址方式传递数据,可以用来返回函数处理结果。实参是数组名时形参可以是指针。,57,6.2 指针,例6-10,58,6.2 指针 6.2.8 用指针作为函数参数,题目:读入三个浮点数,将整数部分和小数部分分别输出#include usi

29、ng namespace std;void splitFloat(float x,int*intPart,float*fracPart)/取x的整数部分*intPart=static_cast(x);/取x的小数部分*fracPart=x-*intPart;,例6-10(续),59,6.2 指针 6.2.8 用指针作为函数参数,int main()cout x;splitFloat(x,60,例6-10(续),运行结果:Enter 3 floating point numbers 4.7Integer Part=4 Fraction Part=0.78.913Integer Part=8 Fr

30、action Part=0.913-4.7518Integer Part=-4 Fraction Part=-0.7518,6.2 指针 6.2.8 用指针作为函数参数,例:输出数组元素的内容和地址,61,6.2 指针 6.2.8 用指针作为函数参数,#include#include using namespace std;void arrayPtr(long*p,int n)cout In func,address of array is p endl;cout Accessing array using pointers endl;for(int i=0;i n;i+)cout Addre

31、ss for index i is p+i;cout Value is*(p+i)endl;,例(续),62,6.2 指针 6.2.8 用指针作为函数参数,int main()long list5=50,60,70,80,90;cout In main,address of array is list endl;cout endl;arrayPtr(list,5);return 0;,63,例(续),运行结果:In main,address of array is 0012FF50In func,address of array is 0012FF50Accessing array using

32、 pointersAddress for index 0 is 0012FF50 Value is 50Address for index 1 is 0012FF54 Value is 60Address for index 2 is 0012FF58 Value is 70Address for index 3 is 0012FF5C Value is 80Address for index 4 is 0012FF60 Value is 90,6.2 指针 6.2.8 用指针作为函数参数,例:指向常量的指针做形参,64,6.2 指针 6.2.8 用指针作为函数参数,#includeusing

33、 namespace std;const int N=6;void print(const int*p,int n);int main()int arrayN;for(int i=0;i arrayi;print(array,N);return 0;void print(const int*p,int n)cout*p;for(int i=1;i n;i+)cout,*(p+i);cout endl;,6.2.9 指针型函数,当函数的返回值是地址时,该函数就是指针形函数。声明形式存储类型 数据类型*函数名(),65,6.2 指针,6.2.10 指向函数的指针,声明形式存储类型 数据类型(*函数

34、指针名)();含义:数据指针指向数据存储区,而函数指针指向的是程序代码存储区。,66,6.2 指针,例6-11 函数指针,67,6.2 指针 6.2.10 指向函数的指针,#include using namespace std;void printStuff(float)cout This is the print stuff function.endl;void printMessage(float data)cout The data to be listed is data endl;void printFloat(float data)cout The data to be prin

35、ted is data endl;,例6-11(续),const float PI=3.14159f;const float TWO_PI=PI*2.0f;int main()/主函数void(*functionPointer)(float);/函数指针printStuff(PI);functionPointer=printStuff;functionPointer(PI);/函数指针调用functionPointer=printMessage;functionPointer(TWO_PI);/函数指针调用functionPointer(13.0);/函数指针调用functionPointer

36、=printFloat;functionPointer(PI);/函数指针调用printFloat(PI);return 0;,68,6.2 指针 6.2.10 指向函数的指针,69,例(续),运行结果:This is the print stuff function.This is the print stuff function.The data to be listed is 6.28318The data to be listed is 13The data to be printed is 3.14159The data to be printed is 3.14159,6.2 指针

37、 6.2.10 指向函数的指针,6.2.11 对象指针,声明形式类名*对象指针名;例:Point a(5,10);Piont*ptr;ptr=,70,6.2 指针,例6-12使用指针来访问Point类的成员,/6_12.cpp#include using namespace std;class Point/类的定义public:/外部接口Point(int x=0,int y=0):x(x),y(y)/构造函数int getX()const return x;/返回xint getY()const return y;/返回yprivate:/私有数据int x,y;,71,6.2 指针 6.2

38、.11 对象指针的一般概念,例6-12(续),72,int main()/主函数Point a(4,5);/定义并初始化对象aPoint*p1=,6.2 指针 6.2.11 对象指针,曾经出现过的错误例子,73,class Fred;/前向引用声明class Barney Fred x;/错误:类Fred的声明尚不完善;class Fred Barney y;,6.2 指针 6.2.11 对象指针,正确的程序,74,class Fred;/前向引用声明class Barney Fred*x;class Fred Barney y;,6.2 指针 6.2.11 对象指针,this指针,隐含于每一

39、个类的成员函数中的特殊指针。明确地指出了成员函数当前所操作的数据所属的对象。当通过一个对象调用成员函数时,系统先将该对象的地址赋给this指针,然后调用成员函数,成员函数对对象的数据成员进行操作时,就隐含使用了this指针。,75,6.2 指针 6.2.11 对象指针,this指针(续),例如:Point类的getX函数中的语句:return x;相当于:return this-x;,76,6.2 指针 6.2.11 对象指针,指向类的非静态成员的指针,通过指向成员的指针只能访问公有成员声明指向成员的指针声明指向公有数据成员的指针类型说明符 类名:*指针名;声明指向公有函数成员的指针类型说明符

40、(类名:*指针名)(参数表);,77,6.2 指针 6.2.11 对象指针,指向类的非静态成员的指针(续),指向数据成员的指针说明指针应该指向哪个成员指针名=&类名:数据成员名;通过对象名(或对象指针)与成员指针结合来访问数据成员对象名.*类成员指针名或:对象指针名-*类成员指针名,78,6.2 指针 6.2.11 对象指针,指向类的非静态成员的指针(续),指向函数成员的指针初始化指针名=&类名:函数成员名;通过对象名(或对象指针)与成员指针结合来访问函数成员(对象名.*类成员指针名)(参数表)或:(对象指针名-*类成员指针名)(参数表),79,6.2 指针 6.2.11 对象指针,例6-13

41、 访问对象的公有成员函数的不同方式,80,int main()/主函数 Point a(4,5);/声明对象APoint*p1=,6.2 指针 6.2.11 对象指针,指向类的静态成员的指针,对类的静态成员的访问不依赖于对象可以用普通的指针来指向和访问静态成员例6-14通过指针访问类的静态数据成员例6-15通过指针访问类的静态函数成员,81,6.2 指针 6.2.11 对象指针,例6-14 通过指针访问类的静态数据成员,82,#include using namespace std;class Point/Point类定义public:/外部接口Point(int x=0,int y=0):x

42、(x),y(y)count+;Point(const Point,6.2 指针 6.2.11 对象指针,例6-14(续),83,int main()/主函数实现/定义一个int型指针,指向类的静态成员int*ptr=,6.2 指针 6.2.11 对象指针,例6-15 通过指针访问类的静态函数成员,84,#include using namespace std;class Point/Point类定义public:/外部接口Point(int x=0,int y=0):x(x),y(y)count+;Point(const Point,6.2 指针 6.2.11 对象指针,例6-15(续),85

43、,int main()/主函数实现/定义一个指向函数的指针,指向类的静态成员函数void(*funcPtr)()=Point:showCount;Point a(4,5);/定义对象Acout Point A:a.getX(),a.getY();funcPtr();/输出对象个数,直接通过指针访问静态函数成员Point b(a);/定义对象Bcout Point B:b.getX(),b.getY();funcPtr();/输出对象个数,直接通过指针访问静态函数成员return 0;,6.2 指针 6.2.11 对象指针,86,6.3 动态内存分配,动态申请内存操作符 new,new 类型名T

44、(初始化参数列表)功能:在程序执行期间,申请用于存放T类型对象的内存空间,并依初值列表赋以初值。结果值:成功:T类型的指针,指向新分配的内存;失败:抛出异常。,87,6.3 动态内存分配,释放内存操作符delete,delete 指针p功能:释放指针p所指向的内存。p必须是new操作的返回值。,例6-16 动态创建对象举例,88,#include using namespace std;class Point public:Point():x(0),y(0)coutDefault Constructor called.endl;Point(int x,int y):x(x),y(y)cout

45、Constructor called.endl;Point()coutDestructor called.endl;int getX()const return x;int getY()const return y;void move(int newX,int newY)x=newX;y=newY;private:int x,y;,6.3 动态内存分配,例6-16(续),89,int main()cout Step one:endl;Point*ptr1=new Point;/调用缺省构造函数delete ptr1;/删除对象,自动调用析构函数cout Step two:endl;ptr1=n

46、ew Point(1,2);delete ptr1;return 0;,6.3 动态内存分配,运行结果:Step One:Default Constructor called.Destructor called.Step Two:Constructor called.Destructor called.,90,6.3 动态内存分配,申请和释放动态数组,分配:new 类型名T 数组长度 数组长度可以是任何表达式,在运行时计算释放:delete 数组名p释放指针p所指向的数组。p必须是用new分配得到的数组首地址。,例6-17 动态创建对象数组举例,91,#includeusing namespa

47、ce std;class Point/类的声明同例6-16,略;int main()Point*ptr=new Point2;/创建对象数组ptr0.move(5,10);/通过指针访问数组元素的成员ptr1.move(15,20);/通过指针访问数组元素的成员cout Deleting.endl;delete ptr;/删除整个对象数组return 0;,6.3 动态内存分配,92,例6-17(续),运行结果:Default Constructor called.Default Constructor called.Deleting.Destructor called.Destructor

48、called.,6.3 动态内存分配,93,6.3 动态内存分配,将动态数组封装成类,更加简洁,便于管理建立和删除数组的过程比较繁琐封装成类后更加简洁,便于管理可以在访问数组元素前检查下标是否越界用assert来检查,assert只在调试时生效,例6-18 动态数组类,94,#include#include using namespace std;class Point/类的声明同例6-16;class ArrayOfPoints/动态数组类public:ArrayOfPoints(int size):size(size)points=new Pointsize;ArrayOfPoints()

49、cout=0,6.3 动态内存分配,例6-18(续),95,int main()int count;cout count;ArrayOfPoints points(count);/创建对象数组/通过访问数组元素的成员points.element(0).move(5,0);/通过类访问数组元素的成员points.element(1).move(15,20);return 0;,6.3 动态内存分配,96,例6-18(续),运行结果:Please enter the number of points:2Default Constructor called.Default Constructor c

50、alled.Deleting.Destructor called.Destructor called.,6.3 动态内存分配,97,6.3 动态内存分配,动态创建多维数组,new 类型名T第1维长度第2维长度;如果内存申请成功,new运算返回一个指向新分配内存首地址的指针,是一个T类型的数组,数组元素的个数为除最左边一维外各维下标表达式的乘积。例如:char(*fp)3;fp=new char23;,98,6.3 动态内存分配,char(*fp)3;,fp,fp+1,例6-19 动态创建多维数组,99,#include using namespace std;int main()float(*

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

当前位置:首页 > 建筑/施工/环境 > 农业报告


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号