第1章 程序设计基础与算法.ppt
《第1章 程序设计基础与算法.ppt》由会员分享,可在线阅读,更多相关《第1章 程序设计基础与算法.ppt(45页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、本章主要内容 2.1 程序设计方法与风格 2.2 结构化程序设计 2.3 面向对象的程序设计程序设计基础等级考试大纲要求 1. 程序设计方法与风格。 2. 结构化程序设计。 3. 面向对象的程序设计方法,对象,方法,属性及继承与多态性。参考书:程序设计基础:石峰编著 2003.11面向对象程序设计基础 赵雷 朱晓旭 2003.6,2.1 程序设计方法与风格P8,程序与程序设计方法 程序是具有特定功能的可执行的指令的集合,计算机能够存储并执行各种程序,来完成不同的任务。 程序设计方法是指在设计程序过程中所采取的系统的研究观点和方法。,程序设计方法分类 面向过程的结构化程序设计(如c)面向对象的程
2、序设计 (如VB、c+),2.1 程序设计方法与风格,2. 程序设计风格: 编写程序时所表现出的特点、习惯和逻辑思路,形成良好的程序设计风格,应考虑以下因素: 1)源程序的文档化 2)数据说明方法 3)语句的结构 4)输入和输出,主导的程序设计风格(考点)清晰第一效率第二,2.1 程序设计方法与风格p8,2. 程序设计风格:1)源程序的文档化符号名的命名: 既要符合语法,又要有实际含义,以便理解程序功能。视觉组织: 在程序中利用空格、空行、 缩进技巧使程序层次清晰。正确的程序注释: 序言性注释和功能性注释,序言性注释: 一般位于程序的开头部分,它包括程序标题、程序功能说明、主要算法 、接口说明
3、、程序位置、开发简历、程序设计者 、复审者、复审日期及修改日期等. 功能性注释: 一般嵌在源程序体中,用于描述其后的语句或程序的主要功能.,2.1 程序设计方法与风格,2. 程序设计风格:2)数据说明方法:见名知义数据说明的次序规范化 各种不同种类的数据说明的次序,最好固定下来,易于查找数据属性。说明语句中变量安排有序化 一个语句中需要声明多个变量,应按字母顺序排列。使用注释来说明复杂数据的结构,2.1 程序设计方法与风格,2. 程序设计风格:3)语句的结构一行内只写一个语句数据结构要有利于程序的简化,程序要模块化 程序编写要做到清晰第一,效率第二尽量使用库函数避免不必要的转移,避免采用复杂的
4、条件语句不要修补不好的程序,要重新编写,2.1 程序设计方法与风格,2. 程序设计风格:4)输入/输出对输入数据要检查数据的合法性交互式输入数据时应有必要的提示信息应允许缺省值,提高输入数据的效率若用户输入某些数据后可能产生严重后果,应给用户输出必要的提示并要求用户确认(容错处理)输入格式要简单,使得输入的步骤和操作尽可能简单当程序设计语言对输入格式有严格要求时,应保持输入格式与输入语句的一致性输出数据的格式应清晰,美观;输出数据时要加上必要的提示信息,程序设计方法发展的历程 面向过程的程序设计 面向过程的结构化程序设计 面向对象的程序设计,程序设计方法的发展历程 面向过程的程序设计方法,设计
5、语言:高级语言(过程式语言)( Basic语言等)程序构成:数据结构+算法程序目的:用于数学计算主要工作:对解题过程进行详细描述,每一步的 操作用户要亲自编写,缺点:对于庞大、复杂的程序难以开发和维护,例 设al,b2,用Basic编程计算c=a+b dim a as integer, b as integer a=1 b=2 c=a+b,数据结构部分,算法:解决问题的操作步骤,程序设计方法的发展历程 面向过程的结构化程序设计方法,顺序结构,选择结构,当型循环,直到型循环,结构化程序设计的基本结构,结构化程序设计的原则自顶向下: 先总体,后细节,先全局,后局部逐步求精: 对复杂问题,应设计一些
6、子目标 做过渡,逐步细化。模块化: 采用模块分解与功能抽象限制使用goto语句,程序设计方法的发展历程 面向过程的结构化程序设计方法,结构化程序结构特点 1. 按功能划分为若干个基本模块,形成一个树状结构。 2. 各模块间的关系尽可能简单,功能上相对独立;每一模块内部均是由顺序、选择和循环三种基本结构组成。 3. 其模块化实现的具体方法是使用子程序(或过程)。,程序设计方法的发展历程 面向过程的结构化程序设计方法,程序设计方法的发展历程 面向过程的结构化程序设计方法,优点: 有效地将一个较复杂的程序系统设计任务分解成许多易于控制和处理的子任务,便于开发和维护。,程序设计方法的发展历程 面向过程
7、的结构化程序设计方法,缺点:可重用性差、数据安全性差、难以开 发大型软件和图形界面的应用软件把数据和处理数据的过程分离为相互独立的实体。当数据结构改变时,所有相关的处理过程都要进行相应的修改。每一种相对于老问题的新方法都要带来额外的开销。图形用户界面的应用程序,很难用过程来描述和实现,开发和维护也都很困难。,2.3 面向对象的程序设计,面向对象的程序设计思想: 主张从客观世界固有的事物(对象)出发来构造系统,提倡用人类在现实生活中常用的思维方法来认识、理解和描述客观事物。,对象是一个包含数据结构与算法的集合,以人为本好方便啊,对象=数据结构+算法 程序=对象+对象+.,2.3 面向对象的程序设
8、计,面向对象的程序设计对象=数据结构+算法 程序=对象+对象+.特点:是高级语言,具有结构化程序设计特点。将客观事物看作具有属性和行为的对象。不再将问题分解为过程,而是将问题分解为对象,一个复杂对象由若干个简单对象构成。通过抽象找出同一类对象的共同属性和行为,形成类。通过消息实现对象之间的联系,构造复杂系统。通过类的继承与多态实现代码重用(*),2.3 面向对象的程序设计,例:在VB中的工具箱中包含VB中的控件类:如文本框类,命令按钮类等。 设计系统时,用系统提供的类进行系统中对象的布局及对象属性和行为的设置,通过对象间的发送消息完成复杂系统的设计。,2.3 面向对象的程序设计,优点:使程序能
9、够比较直接地反映问题域的本来面目,软件开发人员能够利用人类认识事物所采用的一般思维方法来进行软件开发。,2.3.2面向对象方法的基本概念 对象,一般意义上的对象:是现实世界中一个实际存在的事物。可以是有形的(比如一辆汽车),也可以是无形的(比如一项计划)。,对象有如下特性: :有一个名字以区别于其它对象 :有一个状态用来描述它的某些特征 :有一组操作,每个操作决定了对象的一种功能或行为 :对象的操作分为两类:自身承受的操作、施加于其它对象的操作,是构成世界的一个独立单位,具有:静态特征:可以用某种数据来描述(汽车颜色、载重量)动态特征:对象表现的行为或具有的功能(刹车、启动,有一个人名字叫胡哥
10、,性别男,身高1.80m,体重68kg,可以修电器,可以教计算机课,描述该对象如下:对象的静态特征:性别:男身高:1.80m体重:68kg对象的动态特征:回答身高回答体重回答性别修理电器教计算机课,面向对象方法中的对象:是系统中用来描述客观事物的一个实体,它是用来构成系统的一个基本单位。对象由一组属性和一组行为构成。属性:用来描述对象静态特征的数据项。行为:用来描述对象动态特征的操作序列。,2.3.2 面向对象方法的基本概念对象,如:VB中对象有窗体、控件。窗体属性:Left,Top,Width,Height,Forecolor等窗体行为:移动、显示、隐藏和卸载等。,分类人类通常的思维方法分类
11、所依据的原则抽象忽略事物的非本质特征,只注意那些与当前目标有关的本质特征,从而找出事物的共性,把具有共同性质的事物划分为一类,得出一个抽象的概念。 例如,石头、树木、汽车、房屋等都是人们在长期的生产和生活实践中抽象出的概念。类与对象的关系: 犹如模具与铸件之间的关系,即一般与特殊的关系,一个属于某类的对象称为该类的一个实例。,2.3.2 面向对象方法的基本概念类,如计算机是一个类,包括主机、键盘、显示器,而张三的计算机是一个实例: 奔腾,美国标准101键盘,液晶显示器,2.3.2 面向对象方法的基本概念-类与实例,举例:(1)Integer是一个整数类,任何整数都是整数类的对象。123是Int
12、eger的一个实例。(2) 三个不同对象(三个圆),同一类事物,用Circle类定义。相同属性: 圆心、圆的颜色、圆的半径相同操作: 显示、放大、缩小及移动位置等。,面向对象方法中的类具有相同属性和行为的一组对象的集合,如VB中的窗体类、文本框类等。为属于该类的全部对象提供了抽象的描述,包括数据抽象(即属性抽象)和代码抽象(即行为抽象)两个主要部分。如: 窗体属性描述:Name、Left,Top, Forecolor等窗体行为描述: 移动(move)、显示(show)、隐藏(hide) 等。,2.3.2 面向对象方法的基本概念类,类之间的关系通常有:一般与特殊:某个类实例同时是另一个类的对象,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 基础 算法
限制150内