面向对象程序设计语言基础培训课件

上传人:日度 文档编号:149731944 上传时间:2020-10-29 格式:PPT 页数:387 大小:573.50KB
返回 下载 相关 举报
面向对象程序设计语言基础培训课件_第1页
第1页 / 共387页
面向对象程序设计语言基础培训课件_第2页
第2页 / 共387页
面向对象程序设计语言基础培训课件_第3页
第3页 / 共387页
面向对象程序设计语言基础培训课件_第4页
第4页 / 共387页
面向对象程序设计语言基础培训课件_第5页
第5页 / 共387页
点击查看更多>>
资源描述

《面向对象程序设计语言基础培训课件》由会员分享,可在线阅读,更多相关《面向对象程序设计语言基础培训课件(387页珍藏版)》请在金锄头文库上搜索。

1、第3章 面向对象程序设计语言基础,3.1 面向对象程序设计语言 3.2 C+语言基础 3.3 Java的基础知识,3.1 面向对象程序设计语言,掌握面向对象程序设计,首先应该学习面向对象程序设计语言。当今有很多种编程语言能体现基本的面向对象思想,如C+、Java、Smalltalk、CLOS等,但普遍被推崇的、流行的有两种,即C+和Java。下面将介绍C+和Java的一些基础知识。,3.1.1 程序 程序是有目的的动作序列,它是一种软件。对于程序员来说,程序是以某种语言为工具编制出来的动作序列,它表达了人解决现实世界问题的思想。计算机程序是用计算机程序设计语言所要求的规范书写出来的一系列动作,

2、它表达了程序员要求计算机执行的操作。 对于计算机来说,一组机器指令就是程序。我们所说的机器代码或者机器指令,都是指程序,它是按计算机硬件设计规范的要求编制出来的动作序列。在计算机中,程序通常以文件的形式保存。,3.1.2 语言及其分类 语言按其等级可分为高级语言和低级语言。机器语言和汇编语言都是低级语言。程序语言越低级,程序的描写越复杂,越难懂,程序描述的问题越接近机器。 最早,程序员使用最原始的计算机指令,即机器语言程序。只有机器语言才能被机器识别和运行,这些指令以一串二进制数表示。不久,发明了汇编语言,它可以将机器指令映射为一些能被人读懂的助记符。以后,各种高级语言迅速发展起来。发展过程中

3、,经历了严酷的优胜劣汰过程,最后剩下一些比较优秀的高级语言。C+作为一种多范型语言,就是一种优秀的高级语言。,例如,我们用C+和汇编语言分别来实现表达式a2b+3c?1,用C+实现为a2*b+3*c?1; 用汇编来实现为 mov eax,DWORD PTR b_$ ebp mov ecx,DWORD PTR c_$ ebp mul eax,2 mul ecx,3 add eax,ecx dec eax mov DWORD PTR b_$ ebp,eax,语言越低级,就表明越靠近机器;越高级,就表明越靠近人的表达与理解、越自然。程序语言的发展,是从低级到高级,直到可用人的自然语言来描述。程序语言

4、的发展也是从具体到抽象的发展过程。从上面的例子中可以看出,作为高级语言的C+在实现表达式时要比汇编语言简洁得多。,3.1.3 C+是面向对象程序设计语言 正如第1、2章所述,程序设计方法正在从结构化程序设计走向面向对象程序设计。C语言能够很好地支持结构化范型程序设计,而C+能够很好地支持面向对象范型程序设计。在第4、5章中将介绍用C+来实现面向对象范型的程序设计。,3.2 C+语言基础,3.2.1 C+的发展史 C+仅有二十几年的历史,它是C语言的扩展和完善。C语言是贝尔实验室的Dennis Ritchie在B语言的基础上开发出来的。1972年在一台DEC PDP-11计算机上实现了最初的C语

5、言。到20世纪70年代末,C已经演化为现在所说的“传统的C语言”。Kernighan和Ritchie在1978年出版的The C Programming Language一书中全面地介绍了传统的C语言,,1989年美国国家标准协会制定了C语言的标准(ANSI C)。Kernighan和Ritchie编著的第二版The C Programming Language(1988年版)介绍了ANSI C的全部内容。 至此,C语言以其如下独有的特点风靡了全世界: (1) 语言简洁、紧凑,使用方便、灵活。C语言只有32个关键字,程序书写形式自由。 (2) 丰富的运算符和数据类型。 (3) C语言可以直接访

6、问内存地址,能进行位操作,能够胜任开发操作系统的工作。,(4) 生成的目标代码质量高,程序运行效率高。 (5) 可移植性好。 C语言盛行的同时,也暴露出了其局限性: (1) 类型检查机制相对较弱,这使得程序中的一些错误不能在编译时发现; (2) C本身几乎没有支持代码重用的语言结构,因此一个程序员精心设计的程序很难为其他程序所用;,(3) 当程序的规模达到一定的程度时,程序员很难控制程序的复杂性。 为满足管理程序复杂性的需要和克服C语言的以上缺点,就必须对C语言进行完善或以一种新的语言来代替C语言,C+就是在这种环境下应运而生的。1980年,贝尔实验室的Bjarne Stroustrnp开始对

7、C进行改进和扩充。最初的成果称为“带类的C”,1983年正式取名为C+。在对C+进行了三次修订后,于1994年制定了ANSI C+标准的草案,以后又经过不断完善成为目前的C+。C+仍在不断发展中。,C+包含了整个C,C是建立C+的基础;添加了对面向对象程序设计(OOP)的完全支持。 下面介绍在用C+来实现面向对象程序设计中,必须掌握的C+的关于支持面向对象方面等的语法基础。对C缺乏了解的读者,建议在本书之外,尽快浏览一下C语言的有关内容。,3.2.2 C+基础语法 1. 关键字 关键字是预先定义好的标识符,这些标识符在C+编写程序的时候,有特殊的含义。在C+中共有61个关键字。在程序设计的过程

8、中应注意,程序中用到的其他名字不能与这些关键字有相同的拼法(包括大小写都不能相同)。表3-1给出了C+中定义的关键字。,表3-1 C+中定义的关键字,static,2. 基本数据类型 在程序中要用到数据,数据常以变量或常数的形式来描述。每个变量或常数都有数据类型。变量是存储信息的存储单元,它对应于某个内存空间,用变量名代表其存储空间,程序能在变量中存储和取出值。数据类型用来告诉编译器应为变量分配多少内存空间、怎样组织已分配的内存空间,以及变量中要存储值的类型。数据类型分为基本数据类型和非基本数据类型。非基本数据类型包括数组、指针和结构等类型。基本数据类型有char、int、float、doub

9、le、wchar_t和bool等。图3-1描述了C+的数据类型的分类。,图3-1中的type表示非空的数据类型,是程序员可以自己定义的数据类型。在图3-1中只是给出了常用数据类型和部分数据类型修饰符,它们用来改变基本类型的意义,用于适应各种情况的需要。修饰符有long(长型符)、short(短型符)、signed(有符号)和unsigned(无符号)等。数据类型修饰符确定了该数据所占内存空间的大小和可表示的数值范围。表3-2是16位计算机中各数据类型所能表示的数值范围。,图3-1 C+的数据类型,表3-2 常用基本数据类型描述,3. 变量定义 1) 变量名的命名 C+中变量的命名应该遵守以下规

10、则: (1) 不能是C+关键字; (2) 第一个字符必须是字母或下划线; (3) 不要太长,一般不超过31个字符; (4) 不能以数字开头; (5) 中间不能有空格; (6) 变量名中不能包含“. ; , + ?之类的特殊符号。 (7) 变量名不要与C+中库函数名、类名、和对象名相同。,2) 变量定义方式 在给变量命名时,通常用带有描述性的字符串,例如用area命名一个面积变量,用time命名时间变量。这些变量在应用时,程序员和读者对其意义一目了然。例如: int number; double sum; float length;,3) 变量赋值与初始化 用赋值运算符“=”给变量赋值。变量初始

11、化是指在定义变量时直接给变量赋值,也可以先定义变量,然后用赋值语句给其赋值。并不是所有的变量都需要初始化,未初始化的变量在编译器编译时并不会出错。例如: unsigned short width; double area,radius=23; width=4; 其中,变量width先定义后赋值;而变量radius在定义时初始化;变量area未初始化。这些变量在编译时均不会出现错误。,4) typedef 用typedef可以为一个已有的类型名提供一个同义词,该同义词可以代替该类型在程序中使用。用法是以typedef开始,随后是要表示的类型,最后是同义词和分号。typedef实际上没有定义一个新

12、的数据类型,在建立一个typedef类型时没有分配内存。例如: typedef double profit;/定义double的同义类型 typedef int INT, integer; /定义int的两个同义类型 INT a;/同int a; integer a; /同int a; profit d; /同double d;,3.2.3 常数 1. 实数常数 实数常数的表示方法有两种: (1) 十进制小数。它由数字和小数点组成,如0.123,0.234,0.0等都是十进制数。 (2) 指数形式。如:425e4或425E4表示425104。要注意E或e的前面必须是数字,且E或e后面的指数必须

13、为整数。,实数型常数常分为单精度(float)、双精度(double)和长双精度(long double)3类。在16位计算机中,float型数据在内存中占4个字节,double型数据在内存中占8个字节,long double数据类型在内存中占16个字节。float型提供7位有效数字,double型提供15位有效数字,long double提供19位有效数字。 在C+中,一个实数如果没有说明,则其类型为默认类型double型。要表示float型数,则必须在实数后面加上F或f;要表示long double型数,则必须在实数后面加上L或l。,例如: 3.2f /float型实数 3.2L /lon

14、g double型实数 3.2 /没有说明,故为默认类型double型 2. 字符常数 字符常数是用单引号括起来的一个字符,它分为一般字符常数和特殊字符常数。一般字符常数有a、x等字符,特殊字符常数是以“”开头的字符。表3-3列出了常用的特殊字符。,表3-3 常用的特殊字符,表中列出的字符又称为转义字符,即将反斜杠后面的字符转变成另外的意义。有些是控制字符,如“n”;有些字符是在该字符前加转义字符来表示的,如“”、“”、“”。 在内存中,字符数据以ASCII码存储,即以整数表示,所以字符数据和整型数据在0255(一个字节范围内)之间可以相互赋值。只要注意其表示的范围合理即可。例如: int a

15、=b; /正确,将整型变量赋一个字符值(b的ASCII值为98),char c=97;/正确,将一个字符变量赋一个整型值(97代表的ASCII字符是a) 在下列C+语句中,将自动根据变量定义时的数据类型,来确定输出的究竟是字符类型值还是整型类型值。例如: coutaendl;/输出字符b的ASCII值98 coutcendl;/输出ASCII值97的字符b 上面两行语句自动根据a或c被定义的数据类型确定其输出结果及类型。,3. 字符串常数 字符串常数是由一对双引号括起来的字符序列,字符串常数和字符常数是不同的,字符串常数总是以“0”结束。如果一个字符串常数为“welcome”,那么它在内存中占用连续8个内存字节。在编程时应注意变量类型的匹配,不能将字符串常数赋给字符变量。 4. 枚举常数 枚举常数是通过关键字enum来定义的。定义的格式为以enum开始,后跟类型名和花括号。花括号内是要定义的枚举常数(又称为助记常数,该助记常数往往代表一个整型常数值),各常数之间用逗号分隔,最后以分号结束。,例如: enum COLORRED=150,BULE=200,GREEN,WHITE=400; 其中,有一个枚举常数BLUE,代表200;GREEN没有被显式写出,在编译时其值自动被确定为201。如果没有显式地为枚举常量确定值,C+会为其自动确定,即花

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 专业基础教材

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号