版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1,第六章 数组 指针与字符串,面向对象程序设计,2,本章主要内容,数组 指针 动态存储分配 指针与数组 指针与函数 字符串,3,数组的概念,数组是具有一定顺序关系的若干相同类型变量的集合体,组成数组的变量称为该数组的元素。,数 组,4,一维数组的声明与引用,一维数组的声明 类型说明符 数组名 常量表达式 ;,数组的引用 必须先声明,后使用。 只能逐个引用数组元素,而不能一次引用整个数组例如:a0=a5+a7-a2*3,数 组,例如: int a10; 表示 a 为整型数组,有10个元素:a0.a9,5,例6. 1一维数组的声明与引用,#include using namespace std;
2、 void main() int A10,B10; int i; for(i=0;i10;i+) Ai=i*2+1; B10-i-1=Ai; ,数 组,for(i=0;i10;i+) coutAi =Ai; cout Bi = Biendl; ,6,思考:如果从键盘输入10数组元素,从键盘输入,如何处理?,7,一维数组的存储顺序,数组元素在内存中顺次存放,它们的地址是连续的。 例如:具有10个元素的数组 a,在内存中的存放次序如下:,数组名字是数组首元素的内存地址。 数组名是一个常量,不能被赋值。,数 组,8,一维数组的初始化,可以在编译阶段使数组得到初值: 在声明数组时对数组元素赋以初值。例
3、如:static int a10=0,1,2,3,4,5,6,7,8,9; 可以只给一部分元素赋初值。例如:static int a10=0,1,2,3,4; 在对全部数组元素赋初值时,可以不指定数组长度。例如:static int a=1,2,3,4,5,数 组,9,#include using namespace std; void main() int i; static int f20=1,1; /初始化第0、1个数 for(i=2;i20;i+) fi=fi-2+fi-1; /求第219个数 for(i=0;i20;i+) /输出,每行5个数/ if(i%5=0) coutendl;
4、 cout.width(12); /设置输出宽度为12 coutfi; ,例:用数组来处理求Fibonacci数列问题,10,例:用数组来处理求Fibonacci数列问题,运行结果: 11235 813213455 89144233377610 9871597258441816765,11,二维数组的声明及引用,数据类型 标识符常量表达式1常量表达式2 ; 例: int a53; 表示a为整型二维数组,其中第一维有5个下标(04),第二维有3个下标(02),数组的元素个数为15,可以用于存放5行3列的整型数据表格。,数 组,存储顺序 按行存放,上例中数组a的存储顺序为:,二维数组的声明 类型说
5、明符 数组名常量表达式常量表达式 例如:float a34;,二维数组的声明及引用,数 组,12,将所有数据写在一个内,按顺序赋值 例如: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 int a34=1,0,6,0,0,11;,二维数组的初始化,数 组,13,14,数组作为函数参数,数组元素作实参,与单个变量一样。 数组名作参数,形、实参数都应是数组名,类型要一样。 使用数组传递数据时,传递的是地址。
6、 对形参数组的改变会直接影响到实参数组。,数 组,15,对象数组,声明: 类名 数组名元素个数; 访问方法: 通过下标访问 数组名下标.成员名,数 组,16,对象数组初始化,数组中每一个元素对象被创建时,系统都会调用类构造函数初始化该对象。 通过初始化列表赋值。 例:Point A2=Point(1,2),Point(3,4); 如果没有为数组元素指定显式初始值,数组元素便使用默认值初始化(调用默认构造函数)。,数 组,17,例6-3 对象数组应用举例,/Point.h #if !defined(_POINT_H) #define _POINT_H class Point public: Po
7、int(); Point(int xx,int yy); Point(); void Move(int x,int y); int GetX() return X; int GetY() return Y; private: int X,Y; ; #endif,数 组,/6-2.cpp #include using namespace std; #include Point.h Point:Point() X=Y=0; coutDefault Constructor called.endl; Point:Point(int xx,int yy) X=xx; Y=yy; cout Constru
8、ctor called.endl; Point :Point() coutDestructor called.endl; void Point :Move(int x,int y) X=x; Y=y; ,18,#include #include Point.h using namespace std; int main() coutEntering main.endl; Point A2; for(int i=0;i2;i+) Ai.Move(i+10,i+20); coutExiting main.endl; return 0; ,19,运行结果: Entering main. Defaul
9、t Constructor called. Default Constructor called. Exiting main. Destructor called. Destructor called.,20,21,6.2 指针,22,关于内存地址,内存空间的访问方式 通过变量名访问 通过地址访问 地址运算符: 则 static int *i_pointer= 指向整型变量的指针,指针变量的概念,概念 指针:内存地址,用于 间接访问内存单元 指针变量: 用于存放地址的变量,引用 例1: i=3; 例2: *i_pointer=3;,指 针,24,指针变量的声明,语法形式 数据类型 *指针名 数
10、据类型可以是任意类型,指明指针所指的内存单元存放的数据类型。,指 针,int *pa=,25,例6-5 指针的声明、赋值与使用,#include using namespace std; void main() int *i_pointer;/声明int型指针i_pointer int i;/声明int型数i i_pointer= /输出int型指针所指地址的内容 ,指 针,程序运行的结果是: Output int i=10 Output int pointer i=10,26,27,void 类型指针,允许声明指向 void 类型的指针。该指针可以被赋予任何类型对象的地址。 例: void
11、*general;,28,例6-6 void类型指针的使用,void vobject; /错,不能声明void类型的变量 void *pv; /对,可以声明void类型的指针 int *pint; int i; void main() /void类型的函数没有返回值 pv = /跟变量的强制转换一致 ,指 针,29,指向常量的指针,不能通过指针来改变所指对象的值,但指针本身可以改变,可以指向另外的对象。 例1 char *name1 = John; /name1是一般指针 *name1=A; /编译正确,运行出错 例2 const char *name1 = John; /指向常量的指针 ch
12、ar s=abc; name1=s; /正确,name1本身的值可以改变 *name1=1; /编译时指出错误,指 针,30,指针类型的常量,若声明指针常量,则指针本身的值不能被改变。例: char *const name2 = John; name2=abc; /错误,指针常量值不能改变,31,指针变量的算术运算,指针与整数的加减运算 指针 p 加上或减去 n ,其意义是指针当前指向位置的前方或后方第 n 个数据的地址。 这种运算的结果值取决于指针指向的数据类型。 指针加一,减一运算 指向下一个或前一个数据。 例如:y=*px+ 相当于 y=*(px+) (*和+优先级相同,自右向左运算),
13、指 针,pa,32,pb-1,pb,pb+1,pb+2,*(pb-1),*pb,*(pb+1),*(pb+2),long *pb,33,34,6.2.6指向数组元素的指针,声明与赋值 例: int a10, *pa; pa= 通过指针引用数组元素 经过上述声明及赋值后: *pa就是a0,*(pa+1)就是a1,. ,*(pa+i)就是ai. ai, *(pa+i), *(a+i), pai都是等效的。 不能写 a+,因为a是数组首地址是常量。,指 针,35,例6-7:设有一个int型数组a,有10个元素。 用三种方法输出各元素: 使用数组名和下标 使用数组名和指针运算 使用指针变量,指 针,m
14、ain() int a10; int i; for(i=0; iai; coutendl; for(i=0; i10; i+) coutai; ,使用数组名和下标,36,main() int a10; int i; for(i=0; iai; coutendl; for(i=0; i10; i+) cout*(a+i); ,使用数组名指针运算,使用指针变量,main() int a10; int *p,i; for(i=0; iai; coutendl; for(p=a; p(a+10); p+) cout*p; ,39,指针与多维数组,40,Int a34= 1,3,5,7,9,11,13,
15、15,17,19,21,23;,41,42,6.2.7 指针数组,数组的元素是指针型 例:Point *pa2; 由pa0,pa1两个指针组成,指 针,43,例6-9 二维数组举例 p176-177,#include using namespace std; void main() int array223=11,12,13,21,22,23; for(int i=0;i2;i+) cout*(array2+i)endl; for(int j=0;j3;j+) cout*(*(array2+i)+j) ; /或者 coutarray2ij ; coutendl; ,指 针,在某次运行之后,程序
16、的输出结果为: 0X0065FDE0 /第一行元素的首地址 11,12,13 0X0065FDEC /第二行元素的首地址 21,22,23,44,45,6.2.8 用指针作为函数参数,以地址方式传递数据,可以用来返回函数处理结果。 实参是数组名时形参可以是指针。,指针与函数,46,例6.10,题目:读入三个浮点数,将整数部分和小数部分分别输出 #include using namespace std; void splitfloat(float x, int *intpart, float *fracpart) /形参intpart、 fracpart是指针 *intpart = int(x)
17、;/ 取x的整数部分 *fracpart = x - *intpart; /取x的小数部分 ,void main(void) int i, n; float x, f; cout x; splitfloat(x, ,47,运行结果: Enter three (3) floating point numbers 4.7 Integer Part is 4 Fraction Part is 0.7 8.913 Integer Part is 8 Fraction Part is 0.913 -4.7518 Integer Part is -4 Fraction Part is -0.7518,48
18、,49,6.2.9 指针型函数,当函数的返回值是地址时,该函数就是指针形函数。 声明形式: 数据类型 *函数名(参数表) 功能:要在函数结束时把大量的数据从被调函数返回到主调函数中。,指针与函数,50,int * foo( . ) int* p = new int1000; p0 = . . return p;,51,声明形式 P180 数据类型 (*函数指针名)(形参表 ); 含义: 数据指针指向数据存储区,而函数指针指向的是程序代码存储区。,6.2.10 指向函数的指针,指针与函数,52,函数指针在使用之前也要进行赋值,使函数指针指向一个已经存在的函数代码的起始地址。 格式:函数指针名=函
19、数名,函数指针赋值,53,例6-11函数指针,#include using namespace std; void print_stuff(float data_to_ignore); void print_message(float list_this_data); void print_float(float data_to_print); void (*function_pointer)(float); /声明函数指针,指针与函数,void main() float pi = (float)3.14159; float two_pi = (float)2.0 * pi; print_st
20、uff(pi); /调子程序 function_pointer = print_stuff;/指向函数 function_pointer(pi);/函数指针调用 function_pointer = print_message; function_pointer(two_pi);/函数指针调用 function_pointer(13.0); /函数指针调用 function_pointer = print_float; /指向函数 function_pointer(pi); /函数指针调用 print_float(pi); /子程序 ,54,void print_stuff(float dat
21、a_to_ignore) coutThis is the print stuff function.n; void print_message(float list_this_data) coutThe data to be listed is list_this_dataendl; void print_float(float data_to_print) coutThe data to be printed is data_to_printendl; ,55,运行结果: This is the print stuff function. This is the print stuff fu
22、nction. The data to be listed is 6.283180 The data to be listed is 13.000000 The data to be printed is 3.141590 The data to be printed is 3.141590,56,57,对象指针的一般概念,声明形式 类名 *对象指针名; 例 Point A(5,10); Piont *ptr; ptr=,指 针,58,对象指针应用举例,int main() Point A(5,10); Point *ptr; ptr= ,指 针,59,this指针,隐含于每一个类的成员函数中
23、的特殊指针,明确地指出了成员函数当前所操作的数据所属的对象。,指 针,当通过一个对象调用成员函数时,系统先将该对象的地址赋给this指针,然后调用成员函数,成员函数对对象的数据成员进行操作时,就隐含使用了this指针。,60,this指针,例如:Point类的构造函数体中的语句: X=xx; Y=yy; 相当于: this-X=xx; this-Y=yy;,指 针,61,指向类的非静态成员的指针,通过指向成员的指针只能访问公有成员 声明指向成员的指针 声明指向公有数据成员的指针 类型说明符 类名:*指针名; 声明指向公有函数成员的指针 类型说明符 (类名:*指针名)(参数表);,指 针,62,
24、指向类的非静态成员的指针,指向数据成员的指针 说明指针应该指向哪个成员 指针名=/声明对象A Point *p1= ,指 针,65,指向类的静态成员的指针,对类的静态成员的访问不依赖于对象,可以用普通的指针来指向和访问静态成员。 例6-14 通过指针访问类的静态数据成员 例6-15 通过指针访问类的静态函数成员,指 针,66,例6-14通过指针访问类的静态数据成员,#include using namespace std; class Point/Point类声明 public:/外部接口 Point(int xx=0, int yy=0) X=xx;Y=yy;countP+;/构造函数 Po
25、int(Point /静态数据成员定义性说明,指 针,void main()/主函数 /声明一个int型指针,指向类的静态成员 int *count= ,67,68,例6-15通过指针访问类的静态函数成员,#include using namespace std; class Point/Point类声明 public:/外部接口 /其它函数略 static void GetC() /静态函数成员 cout Object id=countPendl; private:/私有数据成员 int X,Y; static int countP;/静态数据成员引用性说明 ; / 函数实现略 int Po
26、int:countP=0;/静态数据成员定义性说明,指 针,void main()/主函数 /指向函数的指针,指向类的静态成员函数 void (*gc)()=Point:GetC; Point A(4,5);/声明对象A coutPoint A,A.GetX(),A.GetY(); gc(); /输出对象序号,通过指针访问静态函数成员 Point B(A);/声明对象B coutPoint B,B.GetX(),B.GetY(); gc(); /输出对象序号,通过指针访问静态函数成员 ,69,70,动态申请内存操作符 new,new 类型名T(初值列表) 功能:在程序执行期间,申请用于存放T类
27、型对象的内存空间,并依初值列表赋以初值。 结果值:成功:T类型的指针,指向新分配的内存。失败:0(NULL),动态存储分配,71,释放内存操作符delete,delete 指针P 功能:释放指针P所指向的内存。P必须是new操作的返回值。,动态存储分配,72,动态存储分配函数,void *malloc( size ); 参数size:欲分配的字节数 返回值: 成功,则返回void型指针。 失败,则返回空指针。 头文件: 和 ,动态存储分配,73,动态内存释放函数,void free( void *memblock ); 参数memblock: 指针,指向需释放的内存。 返回值:无 头文件: 和
28、 ,动态存储分配,74,6.5 字符串,字符串是用一对双引号括起来的字符序列。 存放形式:按串在字符的排列顺序存放,每个字符占一个字节,并在末尾添加“0”,75,用字符数组存储和处理字符串,字符串 1、字符串常量,例如:china 2、没有字符串变量, 3、用字符数组来存放字符串 4、字符串以0为结束标志,字符串,76,例:static char str8=112,114,111,103,114,97,109,0; static char str8=p,r,o,g,r,a,m,0; static char str8=program; static char str=program;,字符数组的
29、声明、引用和初始化,77,字符串的输入/输出,方法 逐个字符输入输出 将整个字符串一次输入或输出例:char c =China; coutc; 注意 输出字符不包括 0 输出字符串时,输出项是字符数组名,输出时遇到0结束。 输入多个字符串时,以空格分隔;输入单个字符串时其中 不能有空格。,字符串,78,例6-22 输出一个字符串,#include using namespace std; void main() static char c10=I, ,a,m, ,a, ,b,o,y; int i; for(i=0;i10;i+) coutci; coutendl; ,运行结果: I am a
30、boy,字符串,79,#include using namespace std; void main() static char c10=I, ,a,m, ,a, ,b,o,y; int i; for(i=0;i10;i+) coutc; coutendl; ,80,81,整行输入字符串,cin.getline(字符数组名St, 字符个数N, 结束符); 功能:一次连续读入多个字符(可以包括空格),直到读满N个,或遇到指定的结束符(默认为n)。读入的字符串存放于字符数组St中。 读取但不存储结束符。 cin.get(字符数组名St, 字符个数N, 结束符); 功能:一次连续读入多个字符(可以包
31、括空格),直到读满N个,或遇到指定的结束符(默认为n),读入的字符串存放于字符数组St中。 既不读取也不存储结束符。,83,整行输入字符串举例,#include using namespace std; void main (void) char city80; char state80; int i; for (i = 0; i 2; i+) cin.getline(city,80,); cin.getline(state,80,n); cout City: city State: state endl; ,字符串,84,运行结果,Beijing,China City: Beijing Country: China Shanghai,China City: Shanghai Country: China,85,循环从键盘读入若干组选择题答案,计算并输出每组答案的正确率。 每组连续输入5个答案,每个答案可以是a.d。,#include using namespace std; void main(void) char key = a,c,b,a,d; char c; int ques = 0, numques = 5, numcorrect = 0; c
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 北京警察学院《Premiere 视频编辑》2024 - 2025 学年第一学期期末试卷
- 乡镇国土空间规划文本
- 护理法律法规知识课件
- 2026年虚拟现实技术在教育领域的实践报告及未来五至十年教育创新报告
- 新生儿常见意外伤害预防
- 【北师大版】初中生物学八年级上册 期末评估测试卷二(含答案)
- 全期护理的成本效益分析
- 2026年及未来5年中国锻造件行业市场深度分析及发展前景预测报告
- 基于生物识别技术的智能门禁与身份验证系统开发课题报告教学研究课题报告
- 2025年物联网在智能家居报告
- 2024年广东省公务员《申论(省市级)》试题真题及答案
- 民兵集训通知函
- 2025年鸡饲料采购合同
- 模拟电子技术基础 第4版黄丽亚课后参考答案
- 电信营业厅运营方案策划书(2篇)
- JBT 14850-2024 塔式起重机支护系统(正式版)
- 专精特新申报材料范本
- 牵引供电系统短路计算-三相对称短路计算(高铁牵引供电系统)
- (完整版)第一性原理
- 安全技术劳动保护措施管理规定
- 学习主题班会课件 高三寒假攻略
评论
0/150
提交评论