C++语言程序设计 第一章 绪论 成都信息工程学院计算机系.

Slides:



Advertisements
Similar presentations
国家税务总局关于修改企业所得税年度纳税申报表( A 类, 2014 年版) 部分申报表的公告(国家税务总局公告 2016 年第 3 号) 一、对《企业基础信息表》( A )及填报说明修改如下: (一) “107 从事国家非限制和禁止行业 ” 修改为 “107 从事国家限制或禁止行业 ”
Advertisements

“ 软件工程 ” 考试安排 考试方式 每人从给出的题目中选择一题,独立撰写论文一篇。 论文要求 1. 论文既要结合软件工程的理论知识,又要结合自身 的实践体会,特别要联系课设自己的实际工作(请 说明自己在课程设计中所承担的主要工作及自己的 认识、体会、总结)。论文应具有自己的分析、观 点,并有实例分析。
复 习 下列设备哪些是输入设备,哪些是输出设备,哪些既 是输入设备又是输出设备 ? – 鼠标、音箱、扫描仪、 mp3 随身听、打印机、 – 写字板、键盘、麦克风、显示器、 U 盘。 输出设备: – 音箱、打印机、 显示器 输入设备: – 鼠标、扫描仪、 写字板、键盘、 麦克风 输入输出设备 – mp3.
1 1.2 信息的表示与存储  数据:数据是对客观事物的符号表示。 如,数值、文字、语言、图形、图像等都是不同形 式的数据。  信息:信息是既是对客观事物变化和特征的反映,又 是事物之间相互作用、相互联系的表征。 信息必须数字化编码,才能用计算机进行传送、存 储和处理。 信息具有针对性和时效性。
第二节 多媒体技术 文本 图形. 【实践与思考】 多媒体光盘是继报纸、杂志、电视等传统媒体之后又一强势媒体, 具有丰富的表现力、强烈的感染力和灵活的交互性,目前已广泛应 用于现实生活中的各个领域。从媒体分类角度看,光盘属于 ______ 媒 体。 通常,多媒体技术指能够对文本、 ______ 、 ______.
2014 年 12 月 企业所得税年度纳税申报表 (A 类, 2014 版 ) 辅导材料(二) A 企业基础信息 A 主表.
[ Java 程序设计 教程 ] 阎菲 陈利 向郑涛 陈宇峰 中国水利水电出版社.  Java 语言是对软件开发技术有深 远影响、应用前景广泛、具有丰富 的类库、继承了 C++ 传统(摈弃了 某些不足)广泛使用的网络编程语 言。 Java 语言的特性使它可以最大 限度地利用网络。  本章介绍面向对象的基本概念:对.
景观水池渗漏的研究 年级专业:12级土木工程 指导教师: ××× 教 学 点: ××××教学点 新疆工程学院继续教育学院 20 年 月 日
第三章 信息的编程加工和智能化加工.
计算机基础 第一章 计算机基础知识 机电系计算机教研室
江西省基础教育资源网相关操作 江西省基础教育资源网相关操作
第2章 數位資料表示法 2-1 資料型態 2-2 二進位表示法 2-3 各種進位表示法的轉換 2-4 整數表示法 2-5 浮點數表示法
大学计算机基础 山东大学计算机学院 张鹏 高等学校计算机公共教学改革与实践 大学计算机基础 山东大学计算机学院 张鹏
工程定额与计价方法 教材名称:工程建设定额原理与实务
建设工程施工管理 模拟卷 一、单项选择题 1.下列选项中,除( )以外都属于施工机械使用费。 A.购置费 B.安拆费及场外运费 C.折旧费 D.修理费.
第一章 绪论.
阳光工程引导性培训 宁夏自治区盐池县农广校
第3章 需求分析(续) 学习目标 什么是需求建模? 需求分析建模方法 掌握实体—关系图(E—R图); 掌握状态转换图;
門神 在傳統觀念中,門是居住環境中與外界相通的出入口,具有重要的屏障作用。門神顧名思義就是護宅守門的神仙,每逢過年,上至天子百官下至普通百姓,家家戶戶必在門上張貼門神,以保一家平安。 門神種類主要有宅第大門上將軍武門神、內室門戶上祈福文門神,還有童子門神、仙子門神等,形象豐富多樣,皇家貴戚還往往在畫上瀝粉貼金,十分吉祥喜慶。
《毛泽东思想和中国特色社会主义体系概论》 第一章马克思主义中国化两大理论成果
中国电信十月献礼活动 中国电信昌平电信局 2012年10月.
2010年春季开学学校食堂食品安全知识培训 徐汇区食品药品监督所
进出口食品检验监管 基础讲课内容 我国进出口食品安全管理体系介绍 法律法规 进口食品的检验检疫 出口食品的检验检疫.
授课班级 安全技术管理0605班 第 5 次 课 授课时间 2008年3月10日 星期一 授课地点 科技楼401多媒体教室 课题内容:
第八章 信息系统开发概述.
2015版《中国地震动参数区划图》 对我市城乡建设的影响
典型案例---医院.
總務處營繕組簡報 1.業務職掌 2.九十四年度工作績效 3.工程一覽 4.歷年工作成果 5.未來展望 6.困難及建議.
2014年企业所得税汇算清缴相关税收政策 新华区地方税务局 卿继红
第十章 季节施工 ——冬期施工准备.
危险废物环境管理情况 河南省固体废物管理中心  韩晓晗 2007年6月6日.
第二章 计算机信息处理技术 数据是指能够由计算机处理的数字、字符和符号等。 数值数据:用数字符号表示,如1,2,….
食品添加剂生产许可审查通则起草说明.
提升课堂质量 助推教师成长 促进教学改革 “一师一优课,一课一名师”活动总结 河南省实验小学.
概述 检索图书的检索工具 检索期刊的检索工具 检索特种文献的检索工具
餐饮服务从业人员 食品安全知识培训 孔莉 朔州市食品药品监督管理局.
首次数据采集填报说明 内蒙古自治区校车信息管理系统 靳 丽 内蒙古自治区教育信息中心 2013年5月
防空地下室审批要点 主讲人:陈玉亭.
治超新政相关文件解读 厅执法局 江涛 二零一六年九月.
科技服务业统计 报表填报说明 江苏省科技统计中心 2008年12月 镇江.
关于加强城市排水防涝有关政策解读 吉林省住房和城乡建设厅 臧 锐.
远程教育站点管理 及齐鲁先锋平台的使用 平阴县党员干部现代远程教育中心.
第二章 计算机基础知识 2.1 计算机系统的组成与工作原理 2.2 数制转换及运算 2.3 数据在计算机中的表示.
「以5換1 」的獎勵辦法 獎勵辦法:1. 擔任值日生盡職者,給予1張優點卡。 2. 每週打掃認真者,給予3張優點卡。 3. 熱心公益者,給予
模块1 计算机基本操作技术 项目1.1 认识计算机.
數字系統與資料表示法 電腦的基本單位 數字系統 數值資料表示法 數值資料與算數運算 數碼系統 浮點數表示法 文字表示法 資料來源:周裕達教授.
第5课 计算机中数的表示 计算机中数的表示 信息技术 七年级(上).
陈 峦 副教授 研究院大楼316# 电子科技大学 能源科学与工程学院
資料表示法與數字系統 主講:顧叔財 資料來源: 計算機概論.
A3-1 數字系統 A3-2 資料表示法 A3-3 資料的儲存
第六章 物件導向軟體測試.
文字資料表示法 & 布林代數與數位邏輯.
電腦系統表示資料的單位.
IT&SAMS小組 (IIT - 倉頡輸入法)
实验二 中文版Windows XP基本操作1 2019/4/4.
认识计算机 随着科技的发展计算机已经成为人们学习、工作、生活中不可缺少的一部分。但是在享受计算机带来方便的同时人们却经常被各种各样的软件、硬件问题所困扰。 那么你们究竟有多了解计算机呢? 今天我们就一起来认识计算机。
第1章 基础知识 1.1 微型计算机中数的表示 1.2 二进制编码 1.3 二进制数的运算.
实验6 面向对象分析与设计实验.
校园之路.
多媒体信息编码.
熟能生巧、每日一练: 五分钟打字练习.
2-1 數位化概念 2-2 資料的數位化 ※ 2-3 基本數位邏輯處理
知识点六 草原资源保护法及渔业资源保护法.
資訊基本概念 與 資訊與生涯及資訊的未來發展
文 本 信 息 加 工.
第四章 图元的属性.
多媒体信息编码.
猜數字遊戲.
2017学考复习 多媒体信息编码.
信息及其特征.
Presentation transcript:

C++语言程序设计 第一章 绪论 成都信息工程学院计算机系

本章主要内容 计算机程序设计语言的发展 面向对象的方法 面向对象的软件开发 信息的表示与存储 程序的开发过程

计算机程序 计算机语言的发展 计算机的工作是用程序来控制的 程序是指令的集合。 指令是计算机可以识别的命令。

机器语言与汇编语言 计算机语言的发展 由计算机硬件系统可以识别的二进制指令组成的语言称为机器语言。 计算机发展的初期,软件工程师们只能用机器语言来编写程序。这一阶段,在人类的自然语言和计算机编程语言之间存在着巨大的鸿沟。 汇编语言将机器指令映射为一些可以被人读懂的助记符,如ADD、SUB等。 此时编程语言与人类自然语言间的鸿沟略有缩小,但仍与人类的思维相差甚远。因为它的抽象层次太低,程序员需要考虑大量的机器细节。

高级语言 计算机语言的发展 高级语言屏蔽了机器的细节,提高了语言的抽象层次,程序中可以采用具有一定含义的数据命名和容易理解的执行语句。这使得在书写程序时可以联系到程序所描述的具体事物。

面向对象的语言 计算机语言的发展 出发点: 特点: 更直接地描述客观世界中存在的事物(对象)以及它们之间的关系。 是高级语言。 将客观事物看作具有属性和行为的对象。 通过抽象找出同一类对象的共同属性和行为,形成类。 通过类的继承与多态实现代码重用

面向对象的语言 计算机语言的发展 优点: 使程序能够比较直接地反映问题域的本来面目,软件开发人员能够利用人类认识事物所采用的一般思维方法来进行软件开发。

程序设计方法的发展历程 ——面向过程的程序设计方法 程序设计方法的发展历程 ——面向过程的程序设计方法 面向对象的方法 最早的程序 目的:用于数学计算 主要工作:设计求解问题的过程 缺点:对于庞大、复杂的程序难以开发和维护

程序设计方法的发展历程 ——面向过程的结构化程序设计方法 面向对象的方法 设计思路 自顶向下、逐步求精。采用模块分解与功能抽象,自顶向下、分而治之。 程序结构: 按功能划分为若干个基本模块,形成一个树状结构。 各模块间的关系尽可能简单,功能上相对独立;每一模块内部均是由顺序、选择和循环三种基本结构组成。 其模块化实现的具体方法是使用子程序。

程序设计方法的发展历程 ——面向过程的结构化程序设计方法 面向对象的方法 优点: 有效地将一个较复杂的程序系统设计任务分解成许多易于控制和处理的子任务,便于开发和维护。

程序设计方法的发展历程 ——面向过程的结构化程序设计方法 程序设计方法的发展历程 ——面向过程的结构化程序设计方法 面向对象的方法 缺点:可重用性差、数据安全性差、难以开发大型软件和图形界面的应用软件 把数据和处理数据的过程分离为相互独立的实体。 当数据结构改变时,所有相关的处理过程都要进行相应的修改。 每一种相对于老问题的新方法都要带来额外的开销。 图形用户界面的应用程序,很难用过程来描述和实现,开发和维护也都很困难。

程序设计方法的发展历程 ——面向对象的方法 程序设计方法的发展历程 ——面向对象的方法 面向对象的方法 将数据及对数据的操作方法封装在一起,作为一个相互依存、不可分离的整体——对象。 对同类型对象抽象出其共性,形成类。 类通过一个简单的外部接口,与外界发生关系。 对象与对象之间通过消息进行通信。

程序设计方法的发展历程 ——面向对象的方法 程序设计方法的发展历程 ——面向对象的方法 面向对象的方法 优点: 程序模块间的关系更为简单,程序模块的独立性、数据的安全性就有了良好的保障。 通过继承与多态性,可以大大提高程序的可重用性,使得软件的开发和维护都更为方便。

面向对象的基本概念 ——对象 面向对象的方法 一般意义上的对象: 是现实世界中一个实际存在的事物。 面向对象的基本概念 ——对象 面向对象的方法 一般意义上的对象: 是现实世界中一个实际存在的事物。 可以是有形的(比如一辆汽车),也可以是无形的(比如一项计划)。 是构成世界的一个独立单位,具有 静态特征:可以用某种数据来描述 动态特征:对象所表现的行为或具有的功能

面向对象的基本概念 ——对象 面向对象的方法 面向对象方法中的对象: 面向对象的基本概念 ——对象 面向对象的方法 面向对象方法中的对象: 是系统中用来描述客观事物的一个实体,它是用来构成系统的一个基本单位。对象由一组属性和一组行为构成。 属性:用来描述对象静态特征的数据项。 行为:用来描述对象动态特征的操作序列。

面向对象的基本概念 ——类 面向对象的方法 分类——人类通常的思维方法 分类所依据的原则——抽象 面向对象的基本概念 ——类 面向对象的方法 分类——人类通常的思维方法 分类所依据的原则——抽象 忽略事物的非本质特征,只注意那些与当前目标有关的本质特征,从而找出事物的共性,把具有共同性质的事物划分为一类,得出一个抽象的概念。 例如,石头、树木、汽车、房屋等都是人们在长期的生产和生活实践中抽象出的概念。

面向对象的基本概念 ——类 面向对象的方法 面向对象方法中的"类" 具有相同属性和服务的一组对象的集合 面向对象的基本概念 ——类 面向对象的方法 面向对象方法中的"类" 具有相同属性和服务的一组对象的集合 为属于该类的全部对象提供了抽象的描述,包括属性和行为两个主要部分。 类与对象的关系: 犹如模具与铸件之间的关系,一个属于某类的对象称为该类的一个实例。

面向对象的基本概念 ——封装 面向对象的方法 把对象的属性和服务结合成一个独立的系统单元。 面向对象的基本概念 ——封装 面向对象的方法 把对象的属性和服务结合成一个独立的系统单元。 尽可能隐蔽对象的内部细节。对外形成一个边界(或者说一道屏障),只保留有限的对外接口使之与外部发生联系。

面向对象的基本概念 ——继承 面向对象的方法 继承对于软件复用有着重要意义,是面向对象技术能够提高软件开发效率的重要原因之一。 面向对象的基本概念 ——继承 面向对象的方法 继承对于软件复用有着重要意义,是面向对象技术能够提高软件开发效率的重要原因之一。 定义:特殊类的对象拥有其一般类的全部属性与服务,称作特殊类对一般类的继承。 例如:将轮船作为一个一般类,客轮便是一个特殊类。

面向对象的基本概念 ——多态性 面向对象的方法 面向对象的基本概念 ——多态性 面向对象的方法 多态是指在一般类中定义的属性或行为,被特殊类继承之后,可以具有不同的数据类型或表现出不同的行为。这使得同一个属性或行为在一般类及其各个特殊类中具有不同的语义。 例如: 数的加法->实数的加法 ->复数的加法

面向对象的软件工程 面向对象的软件开发 面向对象的软件工程是面向对象方法在软件工程领域的全面应用。它包括: 面向对象的分析(OOA) 面向对象的设计(OOD) 面向对象的编程(OOP) 面向对象的测试(OOT) 面向对象的软件维护(OOSM)

系统分析 面向对象的软件开发 系统分析阶段应该扼要精确地抽象出系统必须做什么,但是不关心如何去实现。 面向对象的系统分析,直接用问题域中客观存在的事物建立模型中的对象,对单个事物及事物之间的关系,都保留他们的原貌,不做转换,也不打破原有界限而重新组合,因此能够很好地映射客观事物。

设计 面向对象的软件开发 针对系统的一个具体实现运用面向对象的方法。其中包括两方面的工作: 把OOA模型直接搬到OOD,作为OOD的一部分 针对具体实现中的人机界面、数据存储、任务管理等因素补充一些与实现有关的部分。

编程 面向对象的软件开发 OOP工作就是用一种面向对象的编程语言把OOD模型中的每个成分书写出来,是面向对象的软件开发最终落实的重要阶段。

测试 面向对象的软件开发 测试的任务是发现软件中的错误。 在面向对象的软件测试中继续运用面向对象的概念与原则来组织测试,以对象的类作为基本测试单位,可以更准确地发现程序错误并提高测试效率。

维护 面向对象的软件开发 将软件交付使用后,工作并没有完结,还要根据软件的运行情况和用户的需求,不断改进系统。 使用面向对象的方法开发的软件,其程序与问题域是一致的,因此,在维护阶段运用面向对象的方法可以大大提高软件维护的效率。

信息的表示和存储 信息的分类 计算机的数字系统 程序设计中常用的数制 不同进位计数制间的转换 信息的存储单位 二进制数的编码表示 小数的表示方法 非数值信息的表示

信息的分类 信息的表示与存储 指令 控制信息 控制字 信息 定点数 数值信息 数据信息 浮点数 字符数据 非数值信息 逻辑数据

计算机的数字系统 信息的表示与存储 计算机采用的是二进制数字系统。 基本符号:0、1 进位原则:逢二进一 优点: 缺点:对人来说可读性差 易于物理实现 二进制数运算简单 机器可靠性高 通用性强 缺点:对人来说可读性差

程序设计中常用的数制 信息的表示与存储

不同进位记数制间的转换 ——R 进制→十进制 信息的表示与存储 各位数字与它的权相乘,其积相加。 例如: (11111111.11)2=1×27+1×26+1×25+1×24 +1×23+1×22+1×21+1×20+1×2-1+1×2-2 =(255.75)10 (3506.2)8=3×83+5×82+0×81+6×80+2×8-1 =(1862.25)10 (0.2A)16=2×16-1+10×16-2=(0.1640625)10

不同进位记数制间的转换 ——十进制→ R 进制 信息的表示与存储 十进制整数转换成R进制的整数 “除R取余”法,例如: 2 68 余 数 2 34 ┄┄┄┄┄┄┄┄┄┄┄┄ 0 低位 2 17 ┄┄┄┄┄┄┄┄┄┄┄ 0 2 8 ┄┄┄┄┄┄┄┄┄┄┄ 1 2 4 ┄┄┄┄┄┄┄┄┄┄ 0 2 2 ┄┄┄┄┄┄┄┄┄┄ 0 2 1 ┄┄┄┄┄┄┄┄┄ 0 0 ┄┄┄┄┄┄┄┄┄ 1 高位 所以 6810=10001002

不同进位记数制间的转换 ——十进制→ R 进制 信息的表示与存储 十进制小数转换成R进制小数 “乘 R 取整”法,例如: 高位 0.3125 ×2 = 0 .625 0.625 ×2 = 1 .25 0.25 ×2 = 0 .5 0.5 ×2 = 1 .0 所以 0.312510 = 0.01012

不同进位记数制间的转换 ——二、八、十六进制的相互转换 信息的表示与存储 每位八进制数相当于三位二进制数 每位十六进制数相当于四位二进制数 (1011010.10)2=(001 011 010 .100)2 =(132.4)8 (1011010.10)2=(0101 1010 .1000)2 =(5A.8)16 (F7)16=(1111 0111)2=(11110111)2

信息的存储单位 信息的表示与存储 位(bit,b):度量数据的最小单位,表示一位二进制信息。 字节(byte,B):由八位二进制数字组成(1 byte = 8 bit)。 千字节 1 KB = 1024 B 兆字节 1 MB = 1024 K 吉字节 1 GB = 1024 M

二进制数的编码表示:原码 信息的表示与存储 "符号──绝对值表示"的编码 缺点: 例如: X=+0101011 [X]原= 0 0101011 X=-0101011 [X]原= 1 0101011 符号位 缺点: 零的表示不惟一: [+0]原 =000...0 [-0]原 =100...0 进行四则运算时,符号位须单独处 理,且运算规则复杂。

二进制数的编码表示:反码 信息的表示与存储 正数的反码与原码表示相同。 负数的反码与原码有如下关系: 反码中零的表示也不惟一 符号位相同(仍用1表示),其余各位取反(0变1,1变0)。例如: X=-1100110 [X]原 =11100110 [X]反 =10011001 X=+0000000 [X]原 =00000000 [X]反 =00000000 反码中零的表示也不惟一 X=-0000000 [X]原 =10000000 [X]反 =11111111 反码只是求补码的中间码

二进制数的编码表示:补码 信息的表示与存储 模数: 补数: n位整数(包括一位符号位),则它的模数为 2n 。 n位小数,小数点前一位为符号位,则它的模数为 2。 补数: 一个数减去另一个数,或者说一个数加上一个负数,等于第一个数加上第二个数的补数。例:8+(-2)=8+10 ( mod 12 ) 一个二进制负数可用其模数与真值做 加法 (模减去该数的绝对值) 求得其补 码。

二进制数的编码表示:补码 信息的表示与存储 计算机中的补码表示法 补码运算规则 负数的补码由该数反码的末位加 1 求得 对补码再求补即得到原码 补码运算规则 符号位可作为数值参加运算 减法运算可转换为加法运算: 加上一个负数等于加上该数的补码 补码运算的结果仍为补码 运算结果溢出: 负数之和得正数,或正数之和得负数

小数的表示方法 信息的表示与存储 计算机中通常采用浮点方式表示小数 一个数 N 用浮点形式表示可以写成: N=M×2E E表示2的幂,称为数N的阶码。阶码确定了数N的小数点的位置,其位数反映了该浮点数所表示的数的范围。 M表示数N的全部有效数字,称为数N的尾数。其位数反映了数据的精度。

非数值信息的表示 信息的表示与存储 西文字符: 汉字: ASCII码:用7位二进制数表示一个字符,最多可以表示27=128个字符 EBCDIC码:用8位二进制数表示一个字符,最多可以表示28=256个字符 汉字: 应用较为广泛的是"国家标准信息交换用汉字编码"(GB2312-80标准),简称国标码。是二字节码,用二个七位二进制数编码表示一个汉字。

基本术语 程序的开发过程 源程序: 目标程序: 翻译程序: 用源语言写的,有待翻译的程序 也称为"结果程序",是源程序通过翻译程序加工以后所生成的程序。 翻译程序: 是指一个把源程序翻译成等价的目标程序的程序。

基本术语 ——三种不同类型的翻译程序 程序的开发过程 汇编程序: 编译程序: 基本术语 ——三种不同类型的翻译程序 程序的开发过程 汇编程序: 其任务是把用汇编语言写成的源程序,翻译成机器语言形式的目标程序。 编译程序: 若源程序是用高级程序设计语言所写,经翻译程序加工生成目标程序,那么,该翻译程序就称为"编译程序"。

基本术语 ——三种不同类型的翻译程序 程序的开发过程 解释程序: 基本术语 ——三种不同类型的翻译程序 程序的开发过程 解释程序: 这也是一种翻译程序,同样是将高级语言源程序翻译成机器指令。它与编译程序不同点就在于:它是边翻译边执行的,即输入一句、翻译一句、 执行一句,直至将整个源程序翻译并执行完毕。

程序的开发过程 程序的开发过程 编辑 编译 连接 运行调试 将源程序输入到计算机中,生成后缀为cpp的磁盘文件。 将程序的源代码转换为机器语言代码。 连接 将多个源程序文件以及库中的某些文件连在一起,生成一个后缀为exe的可执行文件。 运行调试

小结与复习建议 简要介绍了如下内容 达到的目标 实验任务 计算机程序设计语言的发展 、面向对象的方法、面向对象的软件开发 、信息的表示与存储 、程序的开发过程 达到的目标 初步了解面向对象的程序设计语言之由来,初步了解面向对象的程序设计思想之基本特点,概要性地了解面向对象的软件开发方法,为后续章节的学习奠定基础。 实验任务 实验一