《C程序设计实验指导与题解课件.ppt》由会员分享,可在线阅读,更多相关《C程序设计实验指导与题解课件.ppt(382页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、2016“”C+程序设计程序设计北京理工大学北京理工大学计算机科学技术学院计算机科学技术学院赵清杰赵清杰2008.7“”C+程序设计程序设计清华大学出版社,清华大学出版社,2008“”主要内容第1章C+语言概述第2章C+编程基础第3章函数与函数模板第4章类与类模板第5章运算符重载第6章继承与派生第7章多态第8章异常处理第9章C+标准库“”第1章C+语言概述“”第1章C+语言概述本章简单介绍C+语言的特点以及C+标准库的主要构成。列举一个简单的C+程序。程序的编辑、编译、连接与运行,并介绍VisualC+6.0开发环境下建立标准C+控制台应用程序的步骤。“”第1章C+语言概述1.1C+语言的特点
2、1.2C+标准库简介1.3简单的C+程序1.4程序的编辑、编译、连接与运行1.5小结“”1.1C+语言的特点支持过程式程序设计proceduralprogramming支持基于对象的程序设计object-basedprogramming支持面向对象的程序设计object-orientedprogramming支持泛型程序设计genericprogrammingC+是一门支持多种编程方法的程序设计语言:是一门支持多种编程方法的程序设计语言:“”1.1C+语言的特点过程式程序设计通过一组算法建立问题的模型,程序的构成就是“算法+数据”。C+能够兼容C语言,但做了很多改进,例如对类型要求更加严格,输
3、入输出更方便,增加了新的运算符,允许函数和运算符重载,增加了引用类型,提供inline、const等关键字。总之,在支持过程式程序设计方面,比C语言更安全、功能更强、使用更方便。基于对象程序设计,主要特征是抽象和封装。它允许将数据和操作封装在一起,形成抽象数据类型,如类。把占据一块内存的类的实例称为该类型的对象。基于对象的程序设计就是建立对象和通过公有接口与对象联系的过程。“”1.1C+语言的特点抽象、封装、继承与多态是面向对象程序设计的主要特征。在类与对象的基础上,C+通过继承和动态绑定机制扩展了抽象数据类型。通过从基类派生出子类,使用户无需修改原有的程序就可以重用已有的资源,并能够进一步修
4、改或增添功能。动态绑定机制通过定义虚函数,使处于不同类层次的同名函数,在程序运行时才被决定应该调用哪一个。泛型程序设计,将算法从特定的数据类型中抽象出来,使算法通用于不同的数据类型。泛型程序在代码重用、组织性、可维护性以及效率等方面表现出很强的优势。C+的模板语法机制,为范型程序设计奠定了关键基础。“”第1章C+语言概述1.1C+语言的特点1.2C+标准库简介1.3简单的C+程序1.4程序的编辑、编译、连接与运行1.5小结“”1.2C+标准库简介C+标准库(StandardLibrary)定义了一些可供直接使用的函数、类、对象等。这些定义分别放在不同的头文件中,我们使用时只要包含相应的头文件即
5、可。以前的C头文件和C+头文件名都是以“.h”做后缀的,如和。新的C+标准头文件名 不 带 后 缀。以 字 母 c开 头 的 标 准 头 文 件(如)等价于原来的C头文件。标准头文件中定义的标识符(如类名、函数名、对象名)都归属于名字空间std,使用时要加前缀“std:”进行限制,或者使用using声明或using指令。C+标准库主要包括流类、string、容器类、使用容器的泛型算法、数值运算、C标准库、语言支持功能等。“”1.2C+标准库简介图图1-1C+标准库构成标准库构成“”1.2C+标准库简介C+(语言)与VisualC+(C+的开发环境)我们要学习的是C+这门计算机语言的语法知识、编
6、程方法以及如何使用C+标准库。不同企业的开发环境一般也为用户提供一个基础类库,如 Microsoft Visual C+的 MFC(MicrosoftFoundation Class Library),Borland C+Builder的VCL(VisualComponentLibrary)等。软件开发人员也可以编写自己的类库。本书我们只涉及C+标准库,而对不同的开发环境及其类库不做具体介绍。“”第1章C+语言概述1.1C+语言的特点1.2C+标准库简介1.3简单的C+程序1.4程序的编辑、编译、连接与运行1.5小结“”1.3简单的C+程序/*/例1-1.计算圆面积的C+程序/数据描述:半径和
7、面积均为实数/数据处理:(a)从键盘输入半径r;/(b)计算面积=r2;(c)向屏幕输出半径和面积/*“”1.3简单的C+程序“”1.3简单的C+程序上述程序运行后,屏幕上显示:Please input radius:如果我们从键盘输入:3屏幕上将显示:radius=3area=28.2743“”1.3简单的C+程序例例1-2.数据的输出#include using namespace std;int main()cout a number in decimal:dec 15endl;cout in octal:oct 15 endl;cout in hex:hex 15 endl;cout
8、a floating-point number:3.14159endl;cout a char:A endl;return 0;“”第1章C+语言概述1.1C+语言的特点1.2C+标准库简介1.3简单的C+程序1.4程序的编辑、编译、连接与运行1.5小结“”编辑:源文件的扩展名为.cpp编译预处理过程预处理过程编译过程编译过程词法分析:单词词法分析:单词语法分析:构造程序的格式语法分析:构造程序的格式符号表:程序中的各种符号及它们的属性符号表:程序中的各种符号及它们的属性错误处理程序:错误处理程序:生成目标代码:目标文件的扩展名为生成目标代码:目标文件的扩展名为.obj连接:可执行文件扩展名为
9、.exe运行1.4程序的编辑、编译、连接与运行“”源程序源程序.cpp目标文件目标文件.obj可执行文件可执行文件.exe编译器编译器连接器连接器#include文件文件C+库文件库文件1.4程序的编辑、编译、连接与运行“”1.4程序的编辑、编译、连接与运行C+编程环境:编程环境:Windows平台下C+的集成开发环境:VisualC+6.0VisualSBorlandC+BuilderLinux下可以采用命令行开发C+程序vi编辑源文件gcc编译源文件“”1.4程序的编辑、编译、连接与运行启动VisualC+6.0开发环境;创建一个新项目;建立C+源程序文件;编辑C+源程序文件内容;编译,连
10、接,调试,执行;关闭工作空间。VisualC+6.0开发环境下,建立标准C+控制台应用程序的步骤:“”第1章C+语言概述1.1C+语言的特点1.2C+标准库简介1.3简单的C+程序1.4程序的编辑、编译、连接与运行1.5小结“”1.5小结C+是一门支持多种编程方法的程序设计语言,它不仅支持过程式程序设计,还支持基于对象的程序设计、面向对象的程序设计以及泛型程序设计。熟悉并学会使用C+标准库。至少熟悉一种C+开发环境。“”第2章C+编程基础“”第2章C+编程基础介绍C+语言的基本概念和基本语法,内容包括C+的词法规则、数据类型、表达式及语句、预处理命令、名字空间等,并通过例子说明相应的语法知识,
11、在此基础上使大家能够编写出简单的C+程序。“”第2章C+编程基础2.1C+的词法规则2.2C+的数据类型2.3表达式与语句2.4预处理命令2.5名字空间2.6小结“”2.1.1 C+的字符集的字符集大小写的英文字母:az,AZ数字字符:09特殊字符:2.1C+的词法规则“”2.1.1 C+的字符集的字符集基本ASCII码是美国标准信息交换码,把128个字符与7位二进制数码对应。C+把字符和它的码值同等看待,字符对应的数值就是该字符的ASCII码。参见例2-1。2.1C+的词法规则“”2.1.2 词汇词汇关键字是C+预定义的单词,表达特定的含义,不允许重定义。C+关键字参见表2-2。2.1C+的
12、词法规则C+的词汇包括关键字、标识符、运算符、分隔符、文字等。“”2.1.2 词汇词汇标识符是程序员声明的单词,例如函数名、类名、对象名等。要求:1)以字母或者下划线开始;2)由字母、数字或者下划线组成。其中区分大/小写,且不能使用预定义的关键字。如_mybook、MyBook、My_book2是合法的,而2a、x+y、new非法。2.1C+的词法规则“”2.1.2 词汇词汇运算符是指实现各种运算的符号,如+、-、*、/等。在C+中,运算符是预定义的函数的名字,这些函数对参与运算的数值进行规定的运算,得到一个结果值。2.1C+的词法规则“”2.1.2 词汇词汇分隔符用于分割各个单词或者程序正文
13、。如:空格、制表(Tab键产生的字符)、换行、逗号、冒号、分号、圆括号、花括号、注释符等。文字在程序中直接表示常量值,包括数字、字符、字符串和布尔文字。2.1C+的词法规则“”第2章C+编程基础2.1C+的词法规则2.2C+的数据类型2.3表达式与语句2.4预处理命令2.5名字空间2.6小结“”基本数据类型是C+预定义的数据类型,或称为内置数据类型:布尔型(bool)、字符型(char)、整型(int)、浮点型(float,double)、空类型(void)。可用signed、unsigned修饰字符型和整型,long可用来修饰整型和双精度浮点型,short可以修饰整型。用户自定义数据类型:在
14、基本数据类型或者已定义的数据类型基础上,用户根据自己的需要,构造出的新类型。如:枚举、联合、结构、类等。将数据与操作数据的算法(函数)封装在一起所建立的类型,又被称作抽象数据类型,在C+中通常指类类型。在已定义的数据类型基础上,结合某些修饰符(如、*、&、())或者关键字(如const),可以得到扩展数据类型,如数组、指针、引用等。2.2C+的数据类型“”布尔型(bool),或逻辑型,占用1个字节,其值只能是真(true)或假(false)两种情况,一般用“1”表示true,用“0”表示false。字符型(char),表示单个ASCII字符或者相应的整数值,占用1个字节。在内存中以ASCII码
15、值的形式存储。整 型(int),修 饰 符 short、long、signed、unsigned。浮点型(float,double),即实数,单精度、双精度和长双精度。空类型(void),表示函数无返回值、或者指针所指对象的类型不明确。2.2.1基本数据类型“”基本数据类型所占用的内存情况参见表2-3。可以通过运算符sizeof,测试在自己的机器环境下某种数据类型或对象所占用的内存大小。如sizeof(float);参见例2-2。2.2.1基本数据类型“”常量:在程序运行过程中,其值不可改变。包括:文字常量、宏定义的符号常量、const常量等。变量:在程序运行过程中,其值可以改变。2.2.2常
16、量与变量“”布尔文字,true,false整型文字,例如,-1000L表示长整数,1000UL表示无符号长整数,U和L不分前后。八进制表示0767L,十六进制表示0 x76fL等。浮点型文字,12.5,.65F,2.5E-3,1e+5F,.28E12L字符文字,(1)A,4;(2)用八进制或十六进制的ASCII码值表示:如A又可以表示为101,或者x41;(3)如n表示换行符,参见表2-4。字符串文字,a,book,以字符0结尾。因此,字符a占一个字节,而字符串a占两个字节。1.文字常量文字常量2.2.2常量与变量“”变量(或对象)一般具有名称(通过new创建的对象没有名称)、类型、数值、地址
17、这四个要素。定义变量时,系统会在内存中为该变量分配一块连续区域,变量的地址就是该区域的首地址。C语言中习惯使用“变量”这个术语。C+中的对象,强调的是分配好的、具体的一块内存区域,并且具有唯一的地址。每个对象都与一个特定的数据类型相关联,这个类型决定了相关内存的大小、布局、能够存储在该区域的值的范围以及可以对该区域进行哪些操作等。数据类型不仅包括基本数据类型,更重要的是抽象数据类型。2.变量与对象变量与对象2.2.2常量与变量“”C+规定,标识符(如对象名、类名、函数名等)在使用之前要先进行声明或定义。声明是告诉编译器“这个标识符在某处进行了定义”。定义是说“在这里建立对象、函数等”,并分配相
18、应的存储空间。大多数情况下对象声明也就是定义,只有对全局对象进行extern声明时例外。floatf1,f2,f3,f4;floatf=2.5;或者floatf(2.5);类对象通过调用构造函数进行初始化。2.变量与对象对象的声明和定义变量与对象对象的声明和定义2.2.2常量与变量“”作用域指标识符在程序正文中的有效范围,例如函数域、类域、名字空间域、文件域(编译单元内有效,一个包含内嵌头文件内容的完整.cpp文件就是一个编译单元)等。一对花括号之间的代码构成一个程序块,在程序块内定义的对象是局部对象,局部对象的作用域从对象的定义点开始,到程序块结束为止。函数(包括主函数)内部定义的对象都是局
19、部对象。可见性讨论的是标识符能否被使用。在具有包含关系的局部作用域中,同名的内层对象将屏蔽外层对象。这时外层对象的标识符是不可见的。在同一作用域中不能对同一个标识符多次定义。2.变量与对象标识符的作用域和可见性变量与对象标识符的作用域和可见性2.2.2常量与变量“”2.变量与对象标识符的作用域和可见性变量与对象标识符的作用域和可见性2.2.2常量与变量“”在函数、类等之外定义的对象,默认情况下的作用范围具有全局性,即在整个程序运行期间起作用,所以称之为全局对象。在局部作用域内,同名的局部对象将屏蔽全局对象。如果想在局部作用域内使用全局对象,则应利用作用域运算符“:”。参见例2-4。如果一个程序
20、包含多个编译单元,那么在一个编译单元中定义的全局对象,不仅在该编译单元可用,在其他编译单元也可以使用,但要先进行extern声明。参见例2-5。对于包含多个编译单元的程序,如果想使全局对象只在定义它的编译单元中起作用,则可以在定义时声明它为static。参见例2-6。2.变量与对象标识符的作用域和可见性变量与对象标识符的作用域和可见性2.2.2常量与变量“”程序中的对象,一般在需要时被创建,不需要时则从内存中删除。在创建和删除之间所经历的时间称为对象的生存期。一般,局部对象的生存期与它的作用域同在,全局对象的生存期与程序的整个执行过程同在。如果想使一个对象在整个程序执行过程中都存在,同时又不希
21、望像全局对象那样存在安全隐患,这时可声明static局部对象。声明静态局部对象时,一般要进行初始化。参见例2-7。2.变量与对象对象的生存期变量与对象对象的生存期2.2.2常量与变量“”一般局部对象的作用域从对象的定义点开始,到它所在的程序块结束为止;生存期与作用域同在。静态局部对象的作用域与一般局部对象相同;生存期与整个程序同在。一般全局对象在程序的任意地方都可以使用;生存期与整个程序同在。静态全局对象具有文件作用域;生存期与整个程序同在。用new建立的堆对象,其作用域和生存期由用户确定。关于作用作用域与生存期的总结:关于作用作用域与生存期的总结:2.2.2常量与变量“”定义对象时,auto
22、、register、static、extern是影响对象存储类型的几个关键字。存储区域类型:(1)静态存储区,全局对象、静态对象和函数一般存储于该区域,存储区在程序开始执行之前分配,在程序的整个运行期间都存在。(2)栈区(stack),程序执行期间进行内存分配。一般局部变量存于栈区。(3)堆区(heap),也称为动态存储区。程序运行时用new申请内存,由程序员负责何时用delete释放内存。不同存储类型的对象,被分配在不同的内存区域参见例2-8。2.变量与对象对象的存储变量与对象对象的存储2.2.2常量与变量“”在C+标准化之前,当需要用符号表示常量时,常用#define宏命令来定义,例如:#
23、definePI3.14159标准C+中用const定义常量,与定义变量的语法类似,只是在前面多了一个关键字const。constdoublepi=3.14159;常量必须进行初始化,而且常量的值不能改变。全局const量,默认具有文件作用域,这一点与一般全局对象不同。如果想使一个const在整个程序可用,那么定义时就要带extern声明。3.常量常量2.2.2常量与变量“”volatile的语法与const类似。关键字const告诉编译器“不要改变我”,而关键字volatile则告诉编译器“我可能会改变”。当编译器不进行优化时,volatile不起作用;但当优化代码时,用该关键字则可以防止出
24、现错误。4.volatile2.2.2常量与变量“”在基本数据类型基础上,用户可以根据需要构造出新的数据类型,如枚举、联合、结构、类等,这些都可以称为自定义数据类型。一旦定义了一种新的数据类型,我们就可以使用这种新类型。2.2.3自定义数据类型“”枚举类型是若干个有名字的整型常量的集合,如:enumShapeCIRCLE=10,SQUARE=0,RECTANGLE=10;花括号内的标识符是枚举常量,多个枚举常量之间用逗号分隔;枚举常量的类型为Shape,具有整数值,可用来初始化或更新Shape类型的对象。如:Shape sh=SQUARE;/对 象 sh初 值 为SQUAREsh=RECTAN
25、GLE;/sh值改为RECTANGLE 2.2.3自定义数据类型1.枚举枚举“”枚举常量的值,最前边的一个默认为为0,其后的值依次加1;枚举常量的值也可显式定义,未显式定义的则在前一个值的基础上加1,如下面BLACK值为0,GREEN值为1,RED值为5,YELLOW值为6:enumColorBLACK,GREEN,BLUE=4,RED,YELLOW2.2.3自定义数据类型1.枚举枚举“”2.2.3自定义数据类型2.联合联合联合类型对象的每个成员都存储在同一位置,最大存储空间的需要量由需要存储空间最大的成员决定。sizeof(A.a)=4 sizeof(A.b)=8 sizeof(A)=8 u
26、nion UnionX int a;double b;UnionX A;/A为对象为对象“”2.2.3自定义数据类型3.结构结构结构类型由其他类型的数据成员组成,如可以把学生的学号、姓名、年龄、成绩等放在一起,定义一种结构类型。sizeof(A.a)=4 sizeof(A.b)=8 sizeof(A)=12 struct StructX int a;double b;StructX A;/A为对象为对象“”2.2.3自定义数据类型4.类类在上面的结构类型中,我们把不同类型的数据封装在一起。那么对于使用这些数据的算法(一般通过函数实现),我们是否也能封装到一起?通过关键字class,可以定义一种
27、新的数据类型,即类,例如:“”2.2.3自定义数据类型4.类类classClassX/定义定义ClassX类类型类类型public:/下面的成员是公有的下面的成员是公有的/成员函数成员函数SetData()voidSetData(intr1,intr2)a=r1;b=r2;private:/下面的成员是私有的下面的成员是私有的inta,b;/声明声明int型数据成员型数据成员a和和b;/注意分号不能少!注意分号不能少!ClassXA;/声明一个对象声明一个对象“”2.2.3自定义数据类型4.类类struct类型中也可以封装成员函数。在C+中,struct类型与class类型的区别是:默认情况下
28、class中的成员具有private访问属性,而struct中的成员具有public访问属性。可以把枚举enum、联合union和结构struct看作是类class的特殊情况。“”2.2.3自定义数据类型5.类模板类模板为了减少程序员的重复劳动,对于功能相同而成员类型不同的类,C+允许声明一个通用的类模板。通过类模板可以生成不同的类。第4章介绍类模板的定义与使用。C+标准库为我们定义了很多可供直接使用的类(模板),如string、pair、complex、valarray、流类、容器类、迭代器等,使用时只要包含相应的头文件即可。“”在基本数据类型或者自定义数据类型基础上,结合运用修饰符(如、*
29、、&、())或者关键字(如const),可以得到扩展数据类型,如数组、指针、引用等。2.2.4扩展数据类型“”2.2.4扩展数据类型1.数组数组数组是数目固定、类型相同的若干个对象的有序集合,这些对象称为数组的元素。数组定义形式:类型数组名维1维2=初值表,初值表;inta5=2,1,3,5,6;intb23=1,0,2,3,6,5;ClassXobj223;“”2.2.4扩展数据类型1.数组数组数组元素的各维下标都从0开始;数组名对应数组的起始地址,是常量;而数组元素一般是变量;各元素在内存中按下标的升序连续存放,如:inta3;/a0,a1,a2intb22;/b00,b01,b10,b1
30、1b0表示含2个元素b00、b01的一维数组,b1表示含2个元素b10、b11的一维数组数组a的元素个数:sizeof(a)/sizeof(a0)“”2.2.4扩展数据类型1.数组数组使用数组时,不能对数组名进行直接拷贝和比较。如果想把一个数组拷贝到另一个中去,可以采用拷贝每个元素的方法。参见例2-11。C+没有提供对数组元素下标进行范围检查的手段。采用C+标准库中的容器vector,可以生成类似数组的对象,且能够进行拷贝、自动调整大小等。参见例2-12。“”2.2.4扩展数据类型2.指针指针指针是指能够存放对象地址的对象。一个类型为T*的指针能够保存T类型对象的地址。指针本身也是一个对象,占
31、据一定的内存空间,具有自己的名字、值和地址。不同的是,指针的值是所指对象的地址,因此我们常说某指针“指向”某个对象。例如:inta=102;int*pa=&a;内存内存1000H102.a1000H2000Hpa“”2.2.4扩展数据类型2.指针指针可以通过指针修改它所指向的对象的值。如:*pa=100;/通过pa修改a的值也可以定义指向类对象的指针,例如:ClassXobj;ClassX*p=&obj;虽然在声明指针时可以不进行初始化,但这样的指针是悬空的,使用时容易出现错误。因此应该养成定义时进行初始化的习惯。“”2.2.4扩展数据类型指针与数组指针与数组在C+程序中,数组名对应数组的起始
32、地址,数组名和指针名经常可以互换使用。参见例2-13。但是,数组和指针是不同的。数组名所指内存区的地址和容量在数组生命期内是不变的。可用sizeof(数组名)算出数组所占的字节数。而指针一般是变量,可以指向类型匹配的任意对象(即不同的内存区)。我们无法知道指针所指内存区的大小。如用sizeof(指针名),得到的是指针本身所占的字节数,而不是所指内存的字节数。也可以定义元素为指针的数组,称为指针数组:double f1=1.8,f2=2.8;double f1=1.8,f2=2.8;double*p2=&f1,&f2;double*p2=&f1,&f2;“”2.2.4扩展数据类型指向常量的指针与
33、常量型指针指向常量的指针与常量型指针定义指针时,如用关键字const修饰所指对象的数据类型,这时的指针就称为指向常量的指针。指向常量的指针可以保存变量或者常量的地址,并且限制指针的访问方式为“只读”,即不能通过指针修改所指对象的值。int v1=3;/变量变量v1const int max=100;/常量常量max,初始化!,初始化!const int*p1=&v1;/指向常量的指针指向常量的指针*p1=5;/错误!错误!p1=&max;/将常量将常量max的地址赋给的地址赋给p1*p1=10;/错误!错误!“”2.2.4扩展数据类型指向常量的指针与常量型指针指向常量的指针与常量型指针定义指针
34、时,如果在指针名前加关键字const修饰,则该指针是常量型指针。常量型指针必须进行初始化,然后指针的值不再改变,即指针的指向不变。但如果常量型指针所指的是变量,则可以通过该指针修改所指变量的值。int v1=10,v2=20;/两变量两变量const int max=100;/常量常量maxint*const pv1=&v1;/常量型指针指向常量型指针指向v1 pv1=&v2;/错误!指向不能再改变错误!指向不能再改变*pv1=v2;/正确!正确!int*const pv2=&max;/错误!错误!“”2.2.4扩展数据类型指向常量的指针与常量型指针指向常量的指针与常量型指针定义指针时,如果对
35、数据类型和指针名都用了关键字const修饰,则这样的指针称为指向常量的常量型指针。这意味着定义之后,指针的值和所指对象的值都不能改变。int v1=10,v2=20;/两个变量两个变量const int max=100;/常量常量maxconst int*const pv1=&v1;const int*const pv2=&max;pv1=&v2;/错误错误!*pv1=v2;/错误错误!“”2.2.4扩展数据类型3.引用引用引用可以理解为对象的别名,其声明形式如下:数据类型数据类型&引用名引用名=被引用的对象名被引用的对象名;int m=0;int&n=m;/n是是int型变量型变量m的引用的
36、引用n=n+5;/结果结果m=5ClassXobj;ClassX&newname=obj;声明引用时必须进行初始化,初值一般必须是对象名;const引用也可用常量或表达式的值初始化。引用一旦被初始化,就不能再指代其他对象。不过一个对象可以有多个引用。“”2.2.4扩展数据类型引用和指针的区别引用和指针的区别指针用来保存对象的地址,引用相当于对象的别名;声明指针时要分配内存(引用型除外),而声明引用时不分配内存;声明引用时必须初始化,声明指针时可以不初始化;指针可作数组元素,引用不能作数组元素;可以有指向void型的指针,而没有void型引用;可以声明指针的引用,而没有指向引用的指针。intin
37、t m1=0,m2=5;m1=0,m2=5;intint*p1=&m1;*p1=&m1;/p1/p1指向指向m1m1intint*&*&p2=p1;p2=p1;/p2/p2是指针是指针p1p1的引用的引用,也指向也指向m1m1*p2=m2;*p2=m2;/将将m2m2的值的值5 5赋给赋给p2p2所指向的对象即所指向的对象即m1m1intint&n1=m1;&n1=m1;/n1/n1是是m1m1的引用的引用intint&*&*n2=n1;n2=n1;/错误!错误!“”2.2.4扩展数据类型4.字符串字符串字符串是若干有效字符的序列。字符串常量由双引号括起来,如x+y=10。字符串可以放在一个字
38、符数组中,结束位置用符号0表示。定义字符数组时,可以逐个字符初始化,也可以用一个字符串常量初始化。例如:char str1=x,+,y,=,1,0,0;char str2=x+y=10;/数组含数组含7个元素个元素“”2.2.4扩展数据类型4.字符串字符串可以通过指向字符的指针管理字符串,例如:charstr1=x,+,y,=,1,0,0;char*cp=str1;/cp保存字符串str1的起始地址对字符指针可以用字符串常量初始化,但不能以数组元素形式初始化,因为cp只存放一个地址值。例如:char*cp1=x+y=10;/cp1保存串的起始地址char*cp2=x,+,y,=,1,0,0;/
39、错误!定义字符串时,最好使用标准库中的类string,该类封装了字符串的基本特性和各种典型操作,如赋值、连接、比较、查找等。参见例2-14。“”2.2.5类型转换在程序编译或者程序运行时,有时需要将一种数据类型转换成另一种类型。类型转换可分为隐式转换和显式转换两大类。其中隐式转换由编译器自动完成,无需编程者介入。一般在运算、函数参数传递及函数值返回时,如果出现数据类型不一致并可以进行自动类型转换时,就会发生隐式转换。显式转换一般要通过类型转换运算符强制实现类型转换,因此也称为强制转换。“”2.2.5类型转换隐式转换由编译器自动完成,运算规则是从低类型向高类型提升。从高类型向低类型转换会给出警告
40、。intint a=3.541+3;/a=3.541+3;/结果结果a a的值为的值为6 6C+可以将某种指针类型(指向非const型)自动转换成void*型,反过来则不行。intint a=0;a=0;intint*p1=&a;*p1=&a;void*void*pvpv=p1;/OK.=p1;/OK.隐式转换隐式转换intint*p2=*p2=pvpv;/错误!错误!void*void*不能隐式转换成不能隐式转换成intint*const const intint*pcipci=&a;=&a;pvpv=pcipci;/;/错误!错误!const const intint*不能隐式转换成不能隐
41、式转换成 void*void*1.隐式转换隐式转换“”2.2.5类型转换可以通过强制类型转换运算符实现类型的显式转换:intint a=1;a=1;double b=3.1415;double b=3.1415;a=(a=(int)bint)b;/C/C风格的显式转换风格的显式转换 a=a=int(bint(b););/早期早期C+C+风格的显式转换风格的显式转换 标准C+显式转换方式:static_caststatic_cast(ExprExpr)const_castconst_cast(ExprExpr)dynamic_castdynamic_cast(ExprExpr)reinterpr
42、et_castreinterpret_cast(ExprExpr)2.显式转换显式转换“”2.2.5类型转换转换构造函数可以将某种类型的对象转换成当前类类型。类型转换函数可以将当前类型的对象转换成指定的类型。用户定义的转换用户定义的转换“”2.2.6typedef与typeidtypedef可以为某种数据类型声明一个新名字。使用运算符typeid可以得到一个对象的数据类型。参见例2-15“”第2章C+编程基础2.1C+的词法规则2.2C+的数据类型2.3表达式与语句2.4预处理命令2.5名字空间2.6小结“”2.3表达式与语句表达式由运算符和操作数组成,按一定求值规则我们可以求出表达式的值;其
43、中操作数可以是常量、变量或另一个表达式。C+简单语句:表达式;程序由语句组成。“”2.3表达式与语句2.3.1运算符与表达式算术运算符与表达式算术运算符与表达式关系运算符与表达式关系运算符与表达式逻辑运算符与表达式逻辑运算符与表达式位运算符与表达式位运算符与表达式三元条件运算符与表达式三元条件运算符与表达式逗号运算符与表达式逗号运算符与表达式动态内存分配与释放运算符动态内存分配与释放运算符2.3.2语句简单语句,复合语句,控制语句(选择语句、循环语句、跳转语句),判断表简单语句,复合语句,控制语句(选择语句、循环语句、跳转语句),判断表达式的使用达式的使用“”2.3.1运算符与表达式根据功能,
44、运算符可分为算术运算符、关系运算符、逻辑运算符、位运算符、赋值运算符及特殊运算符。根据所需操作数的个数,运算符可分为一元运算符、二元运算符和三元运算符。一元运算符只需要一个操作数,二元运算符需要两个操作数,三元运算符则需要三个操作数,C+只有一个三元运算符即“?:”。一个表达式可以包含多个运算符,运算顺序由各运算符的优先级和结合性决定。C+运算符的功能和优先级参见表2-5。“”2.3.1运算符与表达式算术表达式由算术运算符和操作数组成,结果是算术值,值的类型与操作数的类型有关。普通算术运算符:一元算术运算符:一元算术运算符:-(取负)、(取负)、+(取正);(取正);二元算术运算符:二元算术运
45、算符:+、-、*、/、%(%(intint型型);一元运算符优先级高于二元运算符;一元运算符优先级高于二元运算符;+和减-运算符一元运算符,操作数必须是变量,分前缀和后缀;一元运算符,操作数必须是变量,分前缀和后缀;优先级较高,结合性自右向左。优先级较高,结合性自右向左。1.算术运算符与表达式算术运算符与表达式“”2.3.1运算符与表达式前缀“+”可以理解为“先增1后使用”,而前缀“”可以理解为“先减1后使用”。后缀“+”可以理解为“先使用后增1”,后缀“”可以理解为“先使用后减1”。inta1=1,c1=0;c1=+a1;/a1=a1+1;c1=a1;inta2=1,c2=0;c2=a2+;
46、/c2=a2;a2=a2+1;前缀方式与后缀方式的区别前缀方式与后缀方式的区别:“”2.3.1运算符与表达式关系表达式由关系运算符和操作数组成,用来对两个操作数进行比较,结果为bool类型的值。如果关系为真,则结果为true;如果关系为假,则结果为false。关系运算符包括:等于(=),不等于(!=),小于(),小于等于(),大于等于(=)。后四种的优先级高于前两种。例如:设a=1,b=2,则表达式(ab)的值为false,表达式(a2)的值为true。2.关系运算符与表达式关系运算符与表达式“”2.3.1运算符与表达式逻辑表达式由逻辑运算符和操作数组成,结果为bool类型的值。逻辑运算符包括
47、:逻辑或(|)、逻辑与(&)和逻辑非(!)。“逻辑或”表示当两个操作数只要其中一个为真,结果就为true;“逻辑与”表示当两个操作数都为真时,结果才为true;“逻辑非”表示取操作数的逻辑相反值。参见表2-6。3.逻辑运算符与表达式逻辑运算符与表达式“”2.3.1运算符与表达式位运算表达式由位运算符和操作数组成,可以对整型数按二进制位进行操作。位运算符包括:按位或(|),按位异或(),按位与(&),按位求反(),左移()。“按位异或”运算的规则是:对应位不同为1,相同为0。例如:unsignedint a=8;/二进制为00001000unsignedint c=a10;/c=00000010
48、unsignedint b=a1;/b=000100004.位运算符与表达式位运算符与表达式“”2.3.1运算符与表达式赋值表达式由赋值运算符与操作数组成,作用是将等号右边表达式的值赋给等号左边的对象,表达式值的类型与左边对象的类型一致。是二元运算符,结合性自右至左,优先级仅高于逗号运算符。简单赋值(=),复合赋值(+=、-=、*=、/=、%=、&=、|=、=、=)。例如:a=b=5;/先将5赋给b,再赋给aa+=3;/等价于a=a+35.赋值运算符与表达式赋值运算符与表达式“”2.3.1运算符与表达式C+唯一的一个三元运算符是“?:”,具有简单的选择功能,其格式为:a1?a2:a3其中a1具
49、有bool类型,a2和a3可以是任何类型,表达式的类型取决于a2和a3中类型高的一个。上式的运算过程是,若a1为true则表达式值为a2的值,否则表达式值为a3的值。例如求a和b中较大的值,并将该值赋给c,结果c的值为5:inta=3,b=5,c=0;c=(ab)?a:b;6.三元条件运算符与表达式三元条件运算符与表达式“”2.3.1运算符与表达式逗号也是一个运算符,作用是将多个表达式连成一个表达式。计算时从左至右计算每一个表达式的值,逗号表达式的值与最后一个表达式的值相同。例如:a=2*3,a*5;/表达式相当于(a=2*3),a*5上述表达式中,逗号前面赋值表达式的值为6,a*5的值为30
50、,则逗号表达式的值为30。逗号运算符的优先级最低,使用较少。7.逗号运算符与表达式逗号运算符与表达式“”2.3.1运算符与表达式new运算符建立动态对象,并分配内存空间;delete运算符删除动态对象,即释放内存空间。new和delete必须配对使用。由new创建的堆对象没有名字,只能通过地址进行访问,这一点与普通对象不同。例如:int*p1=newint;int*p2=newint(10);int*p3=newint10;deletep1;deletep2;deletep3;8.动态内存分配与释放运算符动态内存分配与释放运算符“”2.3.2语句简单语句:空语句,定义语句,表达式语句复合语句: