清华大学c 教程第一讲.ppt_第1页
清华大学c 教程第一讲.ppt_第2页
清华大学c 教程第一讲.ppt_第3页
清华大学c 教程第一讲.ppt_第4页
清华大学c 教程第一讲.ppt_第5页
已阅读5页,还剩45页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

清华大学软件学院,C+程序设计,清华大学,清华大学软件学院,课程安排,课程名称: C+程序设计 (Programming in C+) 课程目的: 掌握C+程序设计语言和面向对象的软件系统开发方法; 树立软件工程的思想,培养良好规范的编程风格; 在实践中提高自学能力、动手能力;,清华大学软件学院,课程安排,教 材:C+程序设计教程,钱能, 清华大学出版社,1999年. 参考书: C程序设计(第2版), 谭浩强, 清华大学出版社, 1995年. C+Primer(第3版), Stanley B Lippman. The C+ Programming Language (Special Edition), Bjarne Stroustrup, 高等教育出版社, 2001年. ,清华大学软件学院,教学安排(8节课),第一讲 本学期课程综述 面向对象程序设计 第二讲 基本数据类型、表达式 过程化语句 第三讲 函数和程序结构 数组 第四讲 指针和引用 结构、联合,清华大学软件学院,教学安排,第五讲 类和对象 第六讲 继承 第七讲 重载 I/O流 第八讲 模板 异常处理,清华大学软件学院,实验,加强实践环节 编译环境:Visual C+ 6.0 每堂课后布置实验题,要求大家在一周内独立完成; 第4周后布置Project题目,每人选做1题,第9周提交检查。,清华大学软件学院,助教,王 斌:bwangcsis.hku.hk 刘续征:Liu-xz02 董未名:dongwm 姚海龙:yhl02,清华大学软件学院,成绩评定,期末成绩: 出勤、平时实验成绩 30% 期末考试成绩 40% Project完成情况 30% 注意事项: 免修要求 抄袭0分!,清华大学软件学院,第一章 概述,计算机的基本结构 程序设计语言 程序设计方法 早期的程序设计方法 结构化程序设计方法 面向对象程序设计方法 程序开发过程,清华大学软件学院,计算机基本结构,清华大学软件学院,清华大学软件学院,程序设计语言,清华大学软件学院,程序设计方法,早期的程序设计方法 结构化程序设计方法 面向对象程序设计方法,清华大学软件学院,早期的程序设计方法,没有固定程序设计方法。 追求程序的高效率,编程过份依赖技巧,而不注重所编写程序的结构。 程序的可读性、可重用性都很差。 虽然这种方法存在很多问题,但对于单人完成较为简单的任务,事实上还是经常被采用的。,清华大学软件学院,结构化程序设计方法,结构化程序设计采用自顶向下逐步求精的设计方法和单入口单出口的控制结构。 1965年由E.W.Dijkstra提出。 C. Bohm和G. Jacopini证明: 只用3种基本控制结构就能够实现任何单入口单出口的程序。,清华大学软件学院,分支结构,顺序结构,循环结构,清华大学软件学院,逐步求精,结构化程序设计方法是从程序要实现的功能的角度出发的。一般按照自顶向下、逐步求精的方式,将程序要完成的功能逐级划分成许多小的功能模块,象搭积木一样搭起来。这些小的功能模块最终都可以转化成三种基本控制结构的组合。 所谓的功能可以理解为对数据的操作。在程序实现中,特定的功能或功能模块一般用函数来实现,对特定的数据进行操作。,清华大学软件学院,实例,从键盘输入一个学生的信息(包括姓名、年龄、性别、学号等)和一个老师的信息(包括姓名、年龄、性别、是否授课等),然后将信息输出到屏幕。,清华大学软件学院,分析,把问题划分为两个功能模块: 输入模块:负责把信息输入进来,并且保存在变量中; 输出模块:负责把存放在这些变量当中的信息显示在屏幕上。 具体考虑每个模块如何实现(逐步求精) 用C语言实现(参看下面的代码),清华大学软件学院,/ void main() / 主函数开始 / 声明用于存储学生信息的变量 char strStudentName20; / 学生姓名 int nStudentAge; / 学生年龄 char cStudentSex; / 学生性别 int nStudentNumber; / 学生学号 / 声明用于存储老师信息的变量 char strTeacherName20; / 老师姓名 int nTeacherAge; / 老师年龄 char cTeacherSex; / 老师性别 int nIsTeaching; / 是否授课 / 输入模块 GetStudentInfo(); / 输入学生信息 GetTeacherInfo(); / 输入老师信息 / 输出模块 PrintStudentInfo(); / 输出学生信息 PrintStudentInfo(); / 输出老师信息 ,描述学生的数据,描述老师的数据,函数,函数,清华大学软件学院,/ 学生结构Student struct Student char strStudentName20; / 学生姓名 int nStudentAge; / 学生年龄 char cStudentSex; / 学生性别 int nStudentNumber; / 学生学号 ; / 老师结构Teacher struct Teacher char strTeacherName20; / 老师姓名 int nTeacherAge; / 老师年龄 char cTeacherSex; / 老师性别 int nIsTeaching; / 是否教书 ;,清华大学软件学院,进一步将属于学生和老师的变量放入结构中。这样可以在一定程度上完成对数据的封装。 但在结构化程序设计中,数据与对其进行操作的函数仍是分离的。,清华大学软件学院,结构化设计方法的优点,自顶向下逐步求精符合解决复杂问题的普遍规律,可以显著提高开发效率; 用先抽象后具体的逐步求精过程开发的程序具有清晰的层次结构; 单入口单出口的控制结构,程序的静态结构和动态执行情况比较一致; 控制结构有确定的逻辑模式,源程序清晰流畅,易读易懂易测试。,清华大学软件学院,数据量增大时,数据与算法的分离使程序越来越难于理解; 用计算机解题的逻辑来进行程序设计工作,而并不符合人类习惯的思维模式和解决问题的方法。 函数用于完成一定的功能,它们都是针对特定的数据进行操作的。能不能以特定的数据为中心,将数据与对其进行操作的函数封装起来呢?,结构化设计方法的问题,清华大学软件学院,面向对象程序设计方法,面向对象程序设计是建立在结构化程序设计基础上的,但它不再是从功能入手,而是从对象(人、地方、事情等)入手。 面向对象程序设计以类作为构造程序的基本单位,它具有封装、数据抽象、继承、多态等特点。,清华大学软件学院,发展概述,60年代,挪威计算中心的Kristen Nygaard和Ole-Johan Dahl开发了的Simula67语言,首次引入了类、协同程序和子类的概念。 70年代中期,Xerox Palo Alto研究中心的研究人员设计了Smalltalk语言。,清华大学软件学院,但是,面向对象的推广很慢,例如:Smalltalk。 80年代,C成为很受欢迎的程序设计语言,它不仅可用在微机上,还可用在多种结构的系统和环境中。 AT&T贝尔实验室的Bjarne Stroustrup把C语言扩展为支持面向对象程序设计的C+。,清华大学软件学院,自90年代以来,软件与硬件之间的差距越来越大。当软件系统变得更加复杂时,常规软件工具、技术和概念已不足以应付,从而使软件开发者陷入了困境。但面向对象的方法能够控制软件的复杂性,这就促进了面向对象的发展,掀起了一股“面向对象”热。,清华大学软件学院,对象(Object),对象:现实世界中的各种实体。一般都要从属性和行为两个方面来对它们加以描述。 属性:对象具有的一些特征称为属性,这些属性会有其对应的值,一般至少会有一项区别于其它对象,它们在程序设计中对应的是一定的数据。 行为:为了达到目的,对象必须提供的功能(或必须提供的服务)称为对象的行为,在程序设计中对应一定的方法(函数)。,清华大学软件学院,类(Class),类:类描述了一组具有相同属性(数据元素)和相同行为(函数)的对象。 数据成员和成员函数; 类的数据成员是对对象属性的抽象,类的函数成员是对对象行为的抽象,而类本身就是对对象的抽象。,清华大学软件学院,class Student / Student类的声明 public: / 公有成员 Student(); / 构造函数 Student(); / 析构函数 char* GetName(); / 查询姓名 int GetAge(); / 查询年龄 char GetSex(); / 查询姓名 int GetNumber(); / 查询学号 bool SetName(char* n); / 设置姓名 bool SetAge(int age); / 设置年龄 bool SetSex(char* s); / 设置性别 bool SetNumber(int num); / 设置学号 protected: / 保护成员 char m_strName20; / 姓名,字符串数组 int m_nAge; / 年龄,整型 char m_cSex; / 性别,字符型 int m_nNumber; / 学号,整型 ;,例:Student类,成员函数,成员函数,成员变量,清华大学软件学院,结构化程序设计方法是一种模块化程序设计方法,它在解决问题时是以功能为中心的,一定的功能模块虽然也作用于特定的数据,但它们并没有被封装在一起。 面向对象程序设计方法则是以对象为中心来解决问题的。属于同种对象的属性(数据)和服务(功能)被抽象出来封装到一起。,清华大学软件学院,面向对象方法的主要特点,数据抽象 封装 继承 多态 动态绑定,清华大学软件学院,数据抽象,类是一组相似对象的抽象描述,它抽取了这些对象的共性组成了一个共同的概念。抽象数据类型(Abstract Data Type, ADT)是一组相似的类的抽象,而一个类又是ADT的具体实现。,清华大学软件学院,封装性(Encapsulation),封装是指软件的组成部分(模块、子程序、方法等)应该互相独立,或者隐藏设计的细节。在传统的方法中,封装通常局限于将功能和数据分开封装;而在面向对象方法中,封装将功能和数据同时装入对象中。,清华大学软件学院,class Student / Student类的声明 public: / 公有成员 Student(); / 构造函数 Student(); / 析构函数 char* GetName(); / 查询姓名 int GetAge(); / 查询年龄 char GetSex(); / 查询姓名 int GetNumber(); / 查询学号 bool SetName(char* n); / 设置姓名 bool SetAge(int age); / 设置年龄 bool SetSex(char* s); / 设置性别 bool SetNumber(int num); / 设置学号 protected: / 保护成员 char m_strName20; / 姓名,字符串数组 int m_nAge; / 年龄,整型 char m_cSex; / 性别,字符型 int m_nNumber; / 学号,整型 ;,例:C+中类的声明Student类,清华大学软件学院,继承(Inheritance),如果类与类之间有is-a(是一种)的关系,那么可以采用继承机制来表示。子类可以自动继承父类中的一些属性和行为,而不必再进行定义,从而实现了代码的复用。同时,继承也是产生新类的方法之一。,人,学生,教师,清华大学软件学院,class People / People类的声明 public: / 公有成员 People(); / 构造函数 People(); / 析构函数 char* GetName(); / 查询姓名 int GetAge(); / 查询年龄 bool SetName(char* n); / 设置姓名 bool SetAge(int age); / 设置年龄 private: / 私有成员 protected: / 保护成员 char m_strName20; / 姓名,字符串数组 int m_nAge; / 年龄,整型 char m_cSex; / 性别,字符型 ;,类的声明举例People类,清华大学软件学院,class Teacher: public People / Teacher类的声明 public: / 公有成员 Teacher(); / 构造函数 Teacher(); / 析构函数 bool IsTeaching(); / 查询是否授课 private: / 私有成员 protected: / 保护成员 bool m_bIsTeaching / 是否授课 ;,类的声明举例Teacher类,清华大学软件学院,class Student : public People public: Student(); / 构造函数 Student(); / 析构函数 int GetNumber(); / 查询学号 bool SetNumber(int n); / 设置学号 private: protected: int m_nNumber; / 学号 ;,类的声明举例Student类,清华大学软件学院,继承性的优点,共享程序代码和数据结构,减少程序中的冗余信息,提高软件的可重用性; 便于软件修改维护; “站在巨人的肩膀上”;,清华大学软件学院,多态性(Polymorphism),在程序中同一符号或名字在不同情况下具有不同解释的现象称为多态性。 在面向对象程序设计语言中,由程序员设计的多态性由两种基本形式:编译时多态性和运行时多态性。许多程序设计语言都或多或少地支持多态性,但运行时多态性是面向对象程序设计语言的一大特点。,清华大学软件学院,编译时多态性是指在程序编译阶段即可确定下来的多态性,主要通过使用重载(Overloading)机制获得,重载机制包括函数重载和运算符重载两大类。 例子: int Abs(int x); double Abs(double x); coutAbs(-4)endl; /调用i

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论