


单击此处编辑母版标题样式,,单击此处编辑母版文本样式,,第二级,,第三级,,第四级,,第五级,,,*,全国计算机等级考试二级,,C语言程序设计,,,考试方式,,笔试:90分钟 100分,,题型:单选题(40题) 70分,,填空题(15题/空) 30分,,其中:基础30分,,C程序70分,,上机:90分钟 100分,,题型:填空 修改正确得分,,改错 结果运行正确得分,,编程 结果运行正确得分,,试题结构分析,二级C一直以来是整个二级考试中试题最多、难度最大、报考人数也最多的考试,但是从2008年4月份开始笔试由原来120分钟减少到90分钟,所以二级C语言首次题数减少、单个题目难度下降(选择题由原来的50个题目减少到40个,填空由原来的20空减少到15空,满分100分保持不变),从而试题整体难度下降而上机考试时间由原来的60分钟增加至90分钟,但上机题目不仅不加难,反而降低难度所以整个等级考试难度是下降的趋势,08年4月以后开始,等级考试将沿袭这种题型和题量安排等笔试试题分类统计,二级C各章节知识点考察到的题目题号和分值分析:,,C语言初步知识 选择11-13 共3分,,顺序结构 选择14-16 填空7 共5分,,选择结构 选择17-20 填空6 共6分,,循环结构 选择21、22 填空8 共6分,,函数 选择32、34 填空11、13 共8分,,指针/数组/字符串 选择23-27、31、33、35、40 填空10-12 共24分,,预编译与动态内存 选择28、39 共4分,,结构与共用体 选择29、36 填空14 共6分,,位运算 选择38 共2分,,文件 选择30、37 填空15 共6分,,数据结构与算法 选择5-7 填空2、3 共10分,,程序设计基础 选择2 共2分,,软件工程基础 选择1、3、4 填空1 共8分,,数据库设计基础 选择8-10 填空4、5 共10分,,其中:选择1~10每题2分 选择11~20每题1分 选择21~40每题2分 填空1-15空每空2分,,试题特点,1、题数减少,,以前一共50道选择题、20个空的填空题,今年只有40道选择题,15个空的填空题。
试题数的减少,使考生有充足的时间分析和检查题目2、单个题目的难度下级在本次二级C语言笔试试题中,未出现一些特别难的试题,比如没有出现“指向指针的指 针作函数参数”等类型的试题备考建议,:,,大家可以看出,指针、数组、字符串无论在笔试还是上机都是重中之重,既是重点又是难点C语言程序初步、顺序结构、选择结构、循环结构、函数是基础编译预处理、作用域与存储类、位运算、文件等是难点但不是重点,每年都会考到,但题量都不大结构体与共用体可以说比较重点又是难点公共基础部分除了程序设计基础这一部分,其他三部分旗鼓相当,都是重点考试内容,,基础部分30分,,程序设计70分,,上机100分,,基础部分知识要点(30分),,1. 基本数据结构与算法,,2. 程序设计基础,,3. 软件工程基础,,4. 数据库设计基础,,计算机等级考试(二级公共基础)考试大纲,◆ 基本要求,,1.掌握算法的基本概念2.掌握基本数据结构及其操作3.掌握基本排序和查找算法4.掌握逐步求精的结构化程序设计方法5.掌握软件工程的基本方法,具有初步应用相关技术进行软件开发的能力6.掌握数据库的基本知识,了解关系数据库的设计计算机等级考试(二级公共基础)考试大纲,◆ 考试内容,,一、基本数据结构与算法,,1.算法的基本概念;算法复杂度的概念和意义(时间复杂度与空间复杂度)。
2.数据结构的定义;数据的逻辑结构与存储结构;数据结构的图形表示;线性结构与非线性结构的概念3.线性表的定义;线性表的顺序存储结构及其插入与删除运算4.栈和队列的定义;栈和队列的顺序存储结构及其基本运算5.线性单链表、双向链表与循环链表的结构及其基本运算6.树的基本概念;二叉树的定义及其存储结构;二叉树的前序、中序和后序遍历7.顺序查找与二分法查找算法;基本排序算法(交换类排序,选择类排序,插入类排序)计算机等级考试(二级公共基础)考试大纲,◆ 考试内容,,,二、程序设计基础,,1.程序设计方法与风格2.结构化程序设计3.面向对象的程序设计方法,对象,方法,属性及继承与多态性计算机等级考试(二级公共基础)考试大纲,◆ 考试内容,,,三、软件工程基础,,1.软件工程基本概念,软件生命周期概念,软件工具与软件开发环境2.结构化分析方法,数据流图,数据字典,软件需求规格说明书3.结构化设计方法,总体设计与详细设计4.软件测试的方法,白盒测试与黑盒测试,测试用例设计,软件测试的实施,单元测试、集成测试和系统测试5.程序的调试,静态调试与动态调试计算机等级考试(二级公共基础)考试大纲,◆ 考试内容,,,四、数据库设计基础,,1.数据库的基本概念:数据库,数据库管理系统,数据库系统。
2.数据模型,实体联系模型及E-R图,从E-R图导出关系数据模型3.关系代数运算,包括集合运算及选择、投影、连接运算,数据库规范化理论4.数据库设计方法和步骤:需求分析、概念设计、逻辑设计和物理设计的相关策略◆ 考试方式,,公共基础知识有10道选择题和5道填空题,共三十分1. 基本数据结构与算法,1.1 算法,,,算法:是指解题方案的准确而完整的描述算法不等于程序,也不等计算机方法,程序的编制不可能优于算法的设计算法的基本特征,:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此顺序将在有限的次数下终止特征包括:,,(1)可行性;,,(2)确定性,算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义性;,,(3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义;,,(4)拥有足够的情报算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构1. 基本数据结构与算法,指令系统:一个计算机系统能执行的所有指令的集合基本运算和操作包括:算术运算、逻辑运算、关系运算、数据传输算法的控制结构,:顺序结构、选择结构、循环结构。
算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法算法复杂度,:算法时间复杂度和算法空间复杂度算法时间复杂度是指执行算法所需要的计算工作量算法空间复杂度是指执行这个算法所需要的内存空间1. 基本数据结构与算法,算法考试方式及题型分析,,单选题,,算法的时间复杂度是指( ),,A)执行算法程序所需要的时间,,B)算法程序的长度,,C)算法执行过程中所需要的基本运算次数,,D)算法程序中的指令条数,C,,1. 基本数据结构与算法,下面叙述正确的是 ( ),,A. 算法的执行效率与数据的存储结构无关,,B. 算法的空间复杂度是指算法程序中指令(或语句)的条数,,C. 算法的有穷性是指算法必须能在执行有限个步骤之后终止,,D. 以上三种描述都不对,C,,1. 基本数据结构与算法,算法的空间复杂度是指 ( ),,A. 算法程序的长度,,B. 算法程序中的指令条数,,C. 算法程序所占的存储空间,,D. 算法执行过程中所需要的存储空间,D,,1. 基本数据结构与算法,结构化程序设计所规定的三种基本控制结构是( ),,A)输入、处理、输出,,B)树形、网形、环形,,C)顺序、选择、循环,,D)主程序、子程序、函数,C,,1. 基本数据结构与算法,算法一般都可以用哪几种控制结构组合而成。
),,A. 循环、分支、递归,,B. 顺序、循环、嵌套,,C. 循环、递归、选择,,D. 顺序、选择、循环,D,,1. 基本数据结构与算法,在下列选项中,哪个不是一个算法一般应该具有的基本特征( ),,A. 确定性,,B. 可行性,,C. 无穷性,,D. 拥有足够的情报,C,,1. 基本数据结构与算法,在计算机中,算法是指( ),,A. 查询方法,,B. 加工方法,,C. 解题方案的准确而完整的描述,,D. 排序方法,C,,1. 基本数据结构与算法,算法分析的目的是 ( ),,A. 找出数据结构的合理性,,B. 找出算法中输入和输出之间的关系,,C. 分析算法的易懂性和可靠性,,D. 分析算法的效率以求改进,D,,1. 基本数据结构与算法,算法考试方式及题型分析,,填空题,,算法的复杂度主要包括______复杂度和空间复杂度 (时间),,算法的基本特征是可行性、确定性、______和拥有足够的情报 (有穷性),,实现算法所需的存储单元多少和算法的工作量大小分别称为算法的 ______。
空间复杂度和时间复杂度),,,1. 基本数据结构与算法,1.2 数据结构的基本概念,,数据结构研究的三个方面:,,(1)数据集合中各数据元素之间所固有的逻辑关系,即数据的,逻辑结构,;,,(2)在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的,存储结构,;,,(3)对各种数据结构进行的,运,算数据结构是指相互有关联的数据元素的集合数据的逻辑结构包含:,,(1)表示数据元素的信息;,,(2)表示各数据元素之间的前后件关系数据的存储结构有顺序、链接、索引等,线性结构,条件:,,(1)有且只有一个根结点;,,(2)每一个结点最多有一个前件,也最多有一个后件非线性结构,:不满足线性结构条件的数据结构1. 基本数据结构与算法,1.3 线性表及其顺序存储结构,,线性表由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文件非空线性表的结构特征:,,(1)且只有一个根结点a1,它无前件;,,(2)有且只有一个终端结点an,它无后件;,,(3)除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只有一个后件。
结点个数n称为线性表的长度,当n=0时,称为空表线性表的顺序存储结构具有以下两个基本特点:,,(1)线性表中所有元素的所占的存储空间是连续的;,,(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的ai的存储地址为:ADR(ai)=ADR(a1)+(i-1)k,,ADR(a1)为第一个元素的地址,k代表每个元素占的字节数顺序表的运算:插入、删除1. 基本数据结构与算法,1.4 栈和队列,,栈是限定在一端进行插入与删除的线性表,允许插入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底栈按照“先进后出”(FILO)或“后进先出”(LIFO)组织数据,栈具有记忆作用用top表示栈顶位置,用bottom表示栈底栈的基本运算:,,(1)插入元素称为入栈运算;,,(2)删除元素称为退栈运算;,,(3)读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表Rear指针指向队尾,front指针指向队头队列是“先进行出”(FIFO)或“后进后出”(LILO)的线性表队列运算包括,,(1)入队运算:从队尾插入一个元素;,,(2)退队运算:从队头删除一个元素。
循环队列:s=0表示队列空,s=1且front=rear表示队列满,,1. 基本数据结构与算法,1.5 线性链表,,数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点,简称结点结点由两部分组成:,,(1)用于存储数据元素值,称为数据域;,,(2)用于存放指针,称为指针域,用于指向前一个或后一个结点在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的链式存储方式即可用于表示线性结构,也可用于表示非线性结构线性链表,HEAD称为头指针,HEAD=NULL(或0)称为空表,如果是两指针:左指针(Llink)指向前件结点,右指针(Rlink)指向后件结点线性链表的基本运算:查找、插入、删除1. 基本数据结构与算法,1.6 树与二叉树,,树是一种简单的非线性结构,所有元素之间具有明显的层次特性在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结点,简称树的根每一个结点可以有多个后件,称为该结点的子结点没有后件的结点称为叶子结点在树结构中,一个结点所拥有的后件的个数称为该结点的,度,,所有结点中最大的度称为树的,度,。
树的最大层次称为树的,深度,二叉树的特点,:,,(1)非空二叉树只有一个根结点;,,(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树1. 基本数据结构与算法,,二叉树的基本性质,:,,(1)在二叉树的第k层上,最多有2,k-1,(k≥1)个结点;,,(2)深度为m的二叉树最多有2,m,-1个结点;,,(3)度为0的结点(即叶子结点)总是比度为2的结点多一个;,,(4)具有n个结点的二叉树,其深度至少为[log,2,n]+1,其中[log,2,n]表示取log,2,n的整数部分;,,(5)具有n个结点的完全二叉树的深度为[log,2,n]+1;,,1. 基本数据结构与算法,(6)设完全二叉树共有n个结点如果从根结点开始,按层序(每一层从左到右)用自然数1,2,….n给结点进行编号(k=1,2….n),有以下结论:,,①若k=1,则该结点为根结点,它没有父结点;若k>1,则该结点的父结点编号为INT(k/2);,,②若2k≤n,则编号为k的结点的左子结点编号为2k;否则该结点无左子结点(也无右子结点);,,③若2k+1≤n,则编号为k的结点的右子结点编号为2k+1;否则该结点无右子结点。
1. 基本数据结构与算法,满二叉树,是指除最后一层外,每一层上的所有结点有两个子结点,则k层上有2,k-1,个结点深度为m的满二叉树有2,m,-1个结点完全二叉树,是指除最后一层外,每一层上的结点数均达到最大值,在最后一层上只缺少右边的若干结点二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层序进行顺序存储1. 基本数据结构与算法,二叉树的遍历,:,,(1)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;,,(2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子树;,,(3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结点1. 基本数据结构与算法,数据结构考试题型分析,,选择题,,数据的存储结构是指( ),,A. 数据所占的存储空间量,,B. 数据的逻辑结构在计算机中的表示,,C. 数据在计算机中的顺序存储方式,,D. 存储在外存中的数据,B,,1. 基本数据结构与算法,下列叙述中,错误的是(),A)数据的存储结构与数据处理的效率密切相关,,B)数据的存储结构与数据处理的效率无关,,C)数据的存储结构在计算机中所占的空间不一定是连续的,,D)一种数据的逻辑结构可以有多种存储结构,B,,1. 基本数据结构与算法,数据结构中,与所使用的计算机无关的是数据的( ),A)存储结构,,B)物理结构,,C)逻辑结构,,D)物理和存储结构,C,,1. 基本数据结构与算法,根据数据结构中各数据元素之间前后件关系的复杂程度,一般将数据结构分成( ),,A)动态结构和静态结构,,B)紧凑结构和非紧凑结构,,C)线性结构和非线性结构,,D)内部结构和外部结构,C,,1. 基本数据结构与算法,线性表L=(a1,a2,a3,…ai,…an),下列说法正确的是(),A)每个元素都有一个直接前件和直接后件,,B)线性表中至少要有一个元素,,C)表中诸元素的排列顺序必须是由小到大或由大到小,,D)除第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件,D,,1. 基本数据结构与算法,线性表的顺序存储结构和线性表的链式存储结构分别是(),A)顺序存取的存储结构、顺序存取的存储结构,,B)顺序存取的存储结构、随机存取的存储结构,,C)随机存取的存储结构、随机存取的存储结构,,D)随机存取的存储结构、顺序存取的存储结构,B,,1. 基本数据结构与算法,以下数据结构中不属于线性数据结构的是 ( ),A. 队列,,B. 线性表,,C. 二叉树,,D. 栈,C,,1. 基本数据结构与算法,下列关于栈的叙述正确的是( ),,A)栈是非线性结构,,B)栈是一种树状结构,,C)栈具有先进先出的特征,,D)栈具有后进先出的特征,D,,1. 基本数据结构与算法,下列叙述中正确的是( ),,A. 线性表是线性结构,,B. 栈与队列是非线性结构,,C. 线性链表是非线性结构,,D. 二叉树是线性结构,A,,1. 基本数据结构与算法,用链表表示线性表的优点是(),,A. 便于插入和删除操作,,B. 数据元素的物理顺序与逻辑顺序相同,,C. 花费的存储空间较顺序存储少,,D. 便于随机存取,A,,1. 基本数据结构与算法,串的长度是(),A)串中不同字符的个数,,B)串中不同字母的个数,,C)串中所含字符的个数且字符个数大于零,,D)串中所含字符的个数,D,,1. 基本数据结构与算法,下列关于栈的叙述中正确的是( ),,A. 在栈中只能插入数据,,B. 在栈中只能删除数据,,C. 栈是先进先出的线性表,,D. 栈是先进后出的线性表,D,,1. 基本数据结构与算法,下列关于队列的叙述中正确的是( ),,A. 在队列中只能插入数据,,B. 在队列中只能删除数据,,C. 队列是先进先出的线性表,,D. 队列是先进后出的线性表,C,,1. 基本数据结构与算法,栈和队列的共同点是(),,A. 都是先进后出,,B. 都是先进先出,,C. 只允许在端点处插入和删除元素,,D. 没有共同点,C,,1. 基本数据结构与算法,栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是(),,A. ABCED,,B. DBCEA,,C. CDABE,,D. DCBEA,D,,1. 基本数据结构与算法,如果进栈序列为e1,e2,e3,e4,则可能的出栈序列是(),A)e3,,,e1,,,e4,,,e2,,B)e2,,,e4,,,e3,,,e1,,C)e3,,,e4,,,e1,,,e2,,D),任意顺序,B,,1. 基本数据结构与算法,在单链表中,增加头结点的目的是( ),A)方便运算的实现,,B)使单链表至少有一个结点,,C)标识表结点中首结点的位置,,D)说明单链表是线性表的链式存储实现,A,,1. 基本数据结构与算法,非空的循环单链表head的尾结点(由p所指向),满足(),A)p->next==NULL,,B)p==NULL,,C)p->next=head,,D)p=head,C,,1. 基本数据结构与算法,设树T的度为4,其中度为1,2,3,4的结点个数分别为4,2,1,1。
则T中的叶子结点数为(),A)8,,B)7,,C)6,,D)5,A,,1. 基本数据结构与算法,在一棵二叉树上第5层的结点数最多是( ),A. 8,,B. 16,,C. 32,,D. 15,B,,1. 基本数据结构与算法,树是结点的集合,它的根结点数目是(),A),有且只有,1,,B)1,或多于,1,,C)0,或,1,,D)至少2,A,,1. 基本数据结构与算法,设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为( ),A. 349,,B. 350,,C. 255,,D. 351,B,,1. 基本数据结构与算法,若某二叉树的前序遍历访问顺序是abdgcefh,中序遍历访问顺序是dgbaechf,则其后序遍历的结点访问顺序是(),A)bdgcefha,,B)gdbecfha,,C)bdgaechf,,D)gdbehfca,D,,1. 基本数据结构与算法,已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(),A. cedba,,B. acbed,,C. decab,,D. deabc,A,,1. 基本数据结构与算法,设有下列二叉树:,,对此二叉树前序遍历的结果为(),A)ZBTYCPXA,,B)ATBZXCYP,,C)ZBTACYXP,,D)ATBZXCPY,B,T,A,B,Z,X,C,Y,P,,1. 基本数据结构与算法,设有下列二叉树:,,对此二叉树中序遍历的结果为(),A)ABCDEF,,B)DBEAFC,,C)ABDECF,,D)DEBFCA,B,D,A,B,E,C,F,,1. 基本数据结构与算法,数据的逻辑结构在计算机存储空间中的存放形式称为数据的______。
(物理结构),,在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、______遍历和后序遍历 (中序),,设一棵完全二叉树共有500个结点,则在该二叉树中有______个叶子结点250),,数据结构包括数据的______结构和数据的存储结构 (逻辑),,栈的基本运算有三种:入栈、退栈和______读栈顶元素#读栈顶的元素#读出栈顶元素 ),,,,1. 基本数据结构与算法,数据结构包括数据的逻辑结构、数据的 ______以及对数据的操作运算存储结构),,顺序存储方法是把逻辑上相邻的结点存储在物理位置______的存储单元中相邻),,若二叉树度为2的节点数有17个,则叶节点数为,,, (18),,若串s="Program",则其子串的数目是______29),,1. 基本数据结构与算法,1.7 查找技术,,顺序查找的使用情况:,,(1)线性表为无序表;,,(2)表采用链式存储结构。
二分法查找只适用于顺序存储的有序表,对于长度为n的有序线性表,最坏情况只需比较log,2,n次1. 基本数据结构与算法,1.8 排序技术,,排序是指将一个无序序列整理成按值非递减顺序排列的有序序列交换类排序法:,,(1)冒泡排序法,需要比较的次数为n(n-1)/2;,,(2)快速排序法插入类排序法:,,(1)简单插入排序法,最坏情况需要n(n-1)/2次比较;,,(2)希尔排序法,最坏情况需要O(n1.5)次比较选择类排序法:,,(1)简单选择排序法, 最坏情况需要n(n-1)/2次比较;,,(2)堆排序法,最坏情况需要O(nlog,2,n)次比较1. 基本数据结构与算法,排序与查找试题分析,,选择题,,在待排序的元素序列基本有序的前提下,效 率最高的排序方法是(),A)冒泡排序,,B)选择排序,,C)快速排序,,D)归并排序,A,,1. 基本数据结构与算法,希尔排序法属于哪一种类型的排序法 ( ),A. 交换类排序法,,B. 插入类排序法,,C. 选择类排序法,,D. 建堆排序法,B,,1. 基本数据结构与算法,对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为( ),A. N+1,,B. N,,C. (N+1)/2,,D. N/2,B,,1. 基本数据结构与算法,在下列几种排序方法中,要求内存量最大的是( ),A. 插入排序,,B. 选择排序,,C. 快速排序,,D. 归并排序,D,,1. 基本数据结构与算法,已知数据表A中每个元素距其最终位置不远,为节省时间,应采用的算法是( ),A. 堆排序,,B. 直接插入排序,,C. 快速排序,,D. 直接选择排序,B,,1. 基本数据结构与算法,在最坏情况下,堆排序需要比较的次数为______。
(O(nlog,2,n) ),,在最坏情况下,冒泡排序的时间复杂度为______n(n-1)/2#n*(n-1)/2#O(n(n-1)/2)#O(n*(n-1)/2),),,,其他,,n个顶点的强连通图的边数至少有(),,A. n-1,,B. n(n-1),,C. n,,D. n+1,C,,2. 程序设计基础,,2.1 程序设计设计方法和风格,,良好的程序设计风格:,,1、源程序文档化;,,2、数据说明的方法;,,3、语句的结构;,,4、输入和输出注释分序言性注释和功能性注释,语句结构清晰第一、效率第二2. 程序设计基础,,2.2 结构化程序设计,,结构化程序设计方法的四条原则是:1. 自顶向下;2. 逐步求精;3.模块化;4.限制使用goto语句结构化程序的基本结构和特点:,,(1)顺序结构:一种简单的程序设计,最基本、最常用的结构;,,(2)选择结构:又称分支结构,包括简单选择和多分支选择结构,可根据条件,判断应该选择哪一条分支来执行相应的语句序列;,,(3)重复结构:又称循环结构,可根据给定条件,判断是否需要重复执行某一相同程序段2. 程序设计基础,,2.3 面向对象的程序设计,,面向对象的程序设计:以60年代末挪威奥斯陆大学和挪威计算机中心研制的SIMULA语言为标志。
面向对象方法的优点:,,1、与人类习惯的思维方法一致;,,2、稳定性好;,,3、可重用性好;,,4、易于开发大型软件产品;,,5、可维护性好对象是面向对象方法中最基本的概念,可以用来表示客观世界中的任何实体,对象是实体的抽象面向对象的程序设计方法中的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,由一组表示其静态特征的属性和它可执行的一组操作组成2. 程序设计基础,,属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法或服务对象的基本特点:,,1、标识惟一性;,,2、分类性;,,3、多态性;,,4、封装性;,,5、模块独立性好类是指具有共同属性、共同方法的对象的集合所以类是对象的抽象,对象是对应类的一个实例2. 程序设计基础,,消息是一个实例与另一个实例之间传递的信息消息的组成包括:,,1、接收消息的对象的名称;,,2、消息标识符,也称消息名;,,3、零个或多个参数继承是指能够直接获得已有的性质和特征,而不必重复定义他们继承分单继承和多重继承单继承指一个类只允许有一个父类,多重继承指一个类允许有多个父类多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现象。
2. 程序设计基础,,程序设计试题及分析,,选择题,,下面对对象概念描述错误的是(),,A)任何对象都必须有继承性,,B)对象是属性和方法的封装体,,C)对象间的通讯靠消息传递,,D)操作是对象的动态属性,A,,2. 程序设计基础,,在设计程序时,应采纳的原则之一是( ),,A)不限制goto语句的使用,,B)减少或取消注解行,,C)程序越短越好,,D)程序结构应有助于读者理解,D,,2. 程序设计基础,,,结构化程序设计的一种基本方法是(),,A)筛选法,,B)递归法,,C)归纳法,,D)逐步求精法,,D,,2. 程序设计基础,,下面描述中,符合结构化程序设计风格的是(),,A. 使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑,,B. 模块只有一个入口,可以有多个出口,,C. 注重提高程序的执行效率,,D. 不使用goto语句,A,,2. 程序设计基础,,下列叙述中,不属于结构化分析方法的是(),,A)面向数据流的结构化分析方法,,B)面向数据结构的Jackson方法,,C)面向数据结构的结构化数据系统开发方法,,D)面向对象的分析方法,D,,2. 程序设计基础,,结构化程序设计主要强调的是(),,A. 程序的规模,,B. 程序的易读性,,C. 程序的执行效率,,D. 程序的可移植性,B,,2. 程序设计基础,,对建立良好的程序设计风格,下面描述正确的是(),,A. 程序应简单、清晰、可读性好,,B. 符号名的命名要符合语法,,C. 充分考虑程序的执行效率,,D. 程序的注释可有可无,A,,2. 程序设计基础,,下面对对象概念描述错误的是(),,A. 任何对象都必须有继承性,,B. 对象是属性和方法的封装体,,C. 对象间的通讯靠消息传递,,D. 操作是对象的动态性属性,A,,2. 程序设计基础,,对象实现了数据和操作的结合,是指对数据和数据的操作进行(),,A)结合,,B)隐藏,,C)封装,,D)抽象,C,,2. 程序设计基础,,下面概念中,不属于面向对象方法的是(),,A. 对象,,B. 继承,,C. 类,,D. 过程调用,D,,2. 程序设计基础,,在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送(),,A. 调用语句,,B. 命令,,C. 口令,,D. 消息,D,,2. 程序设计基础,,面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是(),,A. 模拟现实世界中不同事物之间的联系,,B. 强调模拟现实世界中的算法而不强调概念,,C. 使用现实世界的概念抽象地思考问题从而自然地解决问题,,D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考,C,,2. 程序设计基础,,结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、______和限制使用goto语句。
(模块化),,面向对象的程序设计方法中涉及的对象是系统中用来描述客观事物的一个____实体),,在面向对象方法中,信息隐蔽是通过对象的______性来实现的 (封装),,一个类可以从直接或间接的祖先中继承所有属性和方法采用这个方法提高了软件的______ (可重用性),,2. 程序设计基础,,面向对象的模型中,最基本的概念是对象和 ______ (类),,Jackson结构化程序设计方法是英国的M.Jackson提出的,它是一种面向______的设计方法 (数据结构),,与结构化需求分析方法相对应的是______方法 (结构化设计),,3. 软件工程基础,,3.1 软件工程基本概念,,计算机软件是包括程序、数据及相关文档的完整集合软件的特点包括:,,(1)软件是一种逻辑实体;,,(2)软件的生产与硬件不同,它没有明显的制作过程;,,(3)软件在运行、使用期间不存在磨损、老化问题;,,(4)软件的开发、运行对计算机系统具有依赖性,受计算机系统的限制,这导致了软件移植的问题;,,(5)软件复杂性高,成本昂贵;,,(6)软件开发涉及诸多的社会因素。
3. 软件工程基础,,软件按功能分为应用软件、系统软件、支撑软件(或工具软件)软件危机主要表现在成本、质量、生产率等问题软件工程是应用于计算机软件的定义、开发和维护的一整套方法、工具、文档、实践标准和工序软件工程包括3个要素:方法、工具和过程软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4种基本活动:,,(1)P——软件规格说明;(2)D——软件开发;(3)C——软件确认;(4)A——软件演进3. 软件工程基础,,软件周期:软件产品从提出、实现、使用维护到停止使用退役的过程软件生命周期三个阶段:软件定义、软件开发、运行维护,主要活动阶段是:,,1、可行性研究与计划制定;,,2、需求分析;,,3、软件设计;,,4、软件实现;,,5、软件测试;,,6、运行和维护3. 软件工程基础,,软件工程的目标和与原则:,,目标:在给定成本、进度的前提下,开发出具有有效性、可靠性、可理解性、可维护性、可重用性、可适应性、可移植性、可追踪性和可互操作性且满足用户需求的产品基本目标:付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能按时完成开发,及时交付使用。
基本原则:抽象、信息隐蔽、模块化、局部化、确定性、一致性、完备性和可验证性3. 软件工程基础,,软件工程的理论和技术性研究的内容主要包括:软件开发技术和软件工程管理软件开发技术包括:软件开发方法学、开发过程、开发工具和软件工程环境软件工程管理包括:软件管理学、软件工程经济学、软件心理学等内容软件管理学包括人员组织、进度安排、质量保证、配置管理、项目计划等软件工程原则包括抽象、信息隐蔽、模块化、局部化、确定性、一致性、完备性和可验证性3. 软件工程基础,,3.2 结构化分析方法,,结构化方法的核心和基础是结构化程序设计理论需求分析方法有:,,1、结构化需求分析方法;,,2、面向对象的分析的方法从需求分析建立的模型的特性来分:静态分析和动态分析结构化分析方法的实质:着眼于数据流,自顶向下,逐层分解,建立系统的处理流程,以数据流图和数据字典为主要工具,建立系统的逻辑模型3. 软件工程基础,,结构化分析的常用工具:,,1、数据流图;2、数据字典;3、判定树;4、判定表数据流图:描述数据处理过程的工具,是需求理解的逻辑模型的图形表示,它直接支持系统功能建模数据字典:对所有与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得用户和系统分析员对于输入、输出、存储成分和中间计算结果有共同的理解。
判定树:从问题定义的文字描述中分清哪些是判定的条件,哪些是判定的结论,根据描述材料中的连接词找出判定条件之间的从属关系、并列关系、选择关系,根据它们构造判定树判定表:与判定树相似,当数据流图中的加工要依赖于多个逻辑条件的取值,即完成该加工的一组动作是由于某一组条件取值的组合而引发的,使用判定表描述比较适宜数据字典是结构化分析的核心3. 软件工程基础,,软件需求规格说明书的特点:,,1、正确性;,,2、无岐义性;,,3、完整性;,,4、可验证性;,,5、一致性;,,6、可理解性;,,7、可追踪性3. 软件工程基础,,3.3 结构化设计方法,,软件设计的基本目标是用比较抽象概括的方式确定目标系统如何完成预定的任务,软件设计是确定系统的物理模型软件设计是开发阶段最重要的步骤,是将需求准确地转化为完整的软件产品或系统的唯一途径3. 软件工程基础,,从技术观点来看,软件设计包括软件结构设计、数据设计、接口设计、过程设计1)结构设计:定义软件系统各主要部件之间的关系2)数据设计:将分析时创建的模型转化为数据结构的定义3)接口设计:描述软件内部、软件和协作系统之间以及软件与人之间如何通信4)过程设计:把系统结构部件转换成软件的过程描述。
3. 软件工程基础,,从工程管理角度来看:概要设计和详细设计软件设计的一般过程:软件设计是一个迭代的过程;先进行高层次的结构设计;后进行低层次的过程设计;穿插进行数据设计和接口设计衡量软件模块独立性使用耦合性和内聚性两个定性的度量标准在程序结构中各模块的内聚性越强,则耦合性越弱优秀软件应高内聚,低耦合3. 软件工程基础,,软件概要设计的基本任务是:,,1、设计软件系统结构;,,2、数据结构及数据库设计;,,3、编写概要设计文档;,,4、概要设计文档评审3. 软件工程基础,,模块用一个矩形表示,箭头表示模块间的调用关系在结构图中还可以用带注释的箭头表示模块调用过程中来回传递的信息还可用带实心圆的箭头表示传递的是控制信息,空心圆箭心表示传递的是数据结构图的基本形式:基本形式、顺序形式、重复形式、选择形式结构图有四种模块类型:传入模块、传出模块、变换模块和协调模块3. 软件工程基础,,典型的数据流类型有两种:变换型和事务型变换型系统结构图由输入、中心变换、输出三部分组成事务型数据流的特点是:接受一项事务,根据事务处理的特点和性质,选择分派一个适当的处理单元,然后给出结果详细设计:是为软件结构图中的每一个模块确定实现算法和局部数据结构,用某种选定的表达工具表示算法和数据结构的细节。
常见的过程设计工具有:图形工具(程序流程图)、表格工具(判定表)、语言工具(PDL)3. 软件工程基础,,3.4 软件测试,,软件测试定义:使用人工或自动手段来运行或测定某个系统的过程,其目的在于检验它是否满足规定的需求或是弄清预期结果与实际结果之间的差别软件测试的目的:发现错误而执行程序的过程软件测试方法:静态测试和动态测试1)静态测试包括代码检查、静态结构分析、代码质量度量不实际运行软件,主要通过人工进行2)动态测试:是基本计算机的测试,主要包括白盒测试方法和黑盒测试方法,,软件测试过程一般按4个步骤进行:单元测试、集成测试、验收测试(确认测试)和系统测试3. 软件工程基础,,白盒测试方法和黑盒测试,,①白盒测试:在程序内部进行,主要用于完成软件内部操作的验证主要方法有逻辑覆盖、基本基路径测试②黑盒测试:主要诊断功能不对或遗漏、界面错误、数据结构或外部数据库访问错误、性能错误、初始化和终止条件错,用于软件确认主要方法有等价类划分法、边界值分析法、错误推测法、因果图等3. 软件工程基础,,3.5 程序的调试,,程序调试的任务是诊断和改正程序中的错误,主要在开发阶段进行程序调试的基本步骤:,,1、错误定位;,,2、修改设计和代码,以排除错误;,,3、进行回归测试,防止引进新的错误。
软件调试可分表静态调试和动态调试静态调试主要是指通过人的思维来分析源程序代码和排错,是主要的设计手段,而动态调试是辅助静态调试主要调试方法有,:1、强行排错法;2、回溯法;3、原因排除法3. 软件工程基础,,软件工程试题及分析,,选择题,,软件开发的结构化生命周期方法将软件生命周期划分成(),,A)定义、开发、运行维护,,B)设计阶段、编程阶段、测试阶段,,C)总体设计、详细设计、编程调试,,D)需求分析、功能定义、系统设计,A,,3. 软件工程基础,,下列工具中为需求分析常用工具的是(),,A)PAD B)PFD,,C)N-S D)DFD,,,开发大型软件时,产生困难的根本原因是(),,A)大系统的复杂性,,B)人员知识不足,,C)客观世界千变万化,,D)时间紧、任务重,A,D,,3. 软件工程基础,,下面不属于软件工程的3个要素的是( ),,A)工具 B)过程 C)方法 D)环境,,,为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为( ),,A)PAD图 B)N-S图,,C)结构图 D)数据流图,,,在软件工程中,白箱测试法可用于测试程序的内部结构。
此方法将程序看做是( ),,A)路径的集合 B)循环的集合,,C)目标的集合 D)地址的集合,D,B,A,,3. 软件工程基础,,软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指(),,A)模块间的关系,,B)系统结构部件转换成软件的过程描述,,C)软件层次结构,,D)软件开发过程,B,,3. 软件工程基础,,完全不考虑程序的内部结构和内部特征,而只是根据程序功能导出测试用例的测试方法是(),,A)黑箱测试法,,B)白箱测试法,,C)错误推测法,,D)安装测试法,A,,3. 软件工程基础,,数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成下列图符名标识的图符不属于数据流图合法图符的是(),,A)控制流,,B)加工,,C)数据存储,,D)源和终,,分析:数据流图4种基本符号:正方形或立方体代表源点或终点;圆角矩形或圆形代表数据处理;开口矩形或两平行线代表数据存储;箭头代表数据流,A,,3. 软件工程基础,,下列不属于软件调试技术的是(),,A)强行排错法 B)集成测试法,,C)回溯法 D)原因排除法,,,软件生命周期中花费时间最多的阶段是(),,A)详细设计 B)软件编码,,C)软件测试 D)软件维护,,,软件设计中,有利于提高模块独立性的一个准则是(),,A)低内聚低耦合 B)低内聚高耦合,,C)高内聚低耦合 D)高内聚高耦合,C,B,D,,3. 软件工程基础,,信息隐蔽的概念与下述哪一种概念直接相关,?,(),,A)软件结构定义 B)模块独立性,,C)模块类型划分 D)模块耦合度,,,在软件生产过程中,需求信息的给出是(),,A)程序员 B)项目管理者,,C)软件分析设计人员 D)软件用户,,,下列叙述中,不属于测试的特征的是(),,A)测试的挑剔性 B)完全测试的不可能性,,C)测试的可靠性 D)测试的经济性,C,B,D,,3. 软件工程基础,,在结构化设计方法中,生成的结构图(SC)中,带有箭头的连线表示(),,A)模块之间的调用关系 B)程序的组成成分,,C)控制程序的执行顺序 D)数据的流向,,,检查软件产品是否符合需求定义的过程称为(),,A)确认测试 B)集成测试,,C)验证测试 D)验收测试,,,下面不属于软件设计原则的是(),,A)抽象 B)模块化,,C)自底向上 D)信息隐蔽,C,A,A,,3. 软件工程基础,,下面不属于静态测试方法的是(),,A)代码检查 B)白盒法,,C)静态结构分析 D)代码质量度量,,,在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是( ),,A. 可行性分析 B. 需求分析,,C. 详细设计 D. 程序编码,,,在软件开发中,下面任务不属于设计阶段的是( ),,A. 数据结构设计 B. 给出系统模块结构,,C. 定义模块算法 D. 定义需求并建立系统模型,D,B,B,,3. 软件工程基础,,在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是( ),,A. 概要设计 B. 详细设计,,C. 可行性分析 D. 需求分析,,,软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及( ),,A. 阶段性报告 B. 需求评审,,C. 总结 D. 都不正确,,,下面不属于软件工程的3个要素的是( ),,A. 工具 B. 过程,,C. 方法 D. 环境,D,D,B,,3. 软件工程基础,,程序流程图(PFD)中的箭头代表的是( ),,A. 数据流 B. 控制流,,C. 调用关系 D. 组成关系,,,检查软件产品是否符合需求定义的过程称为( ),,A. 确认测试 B. 集成测试,,C. 验证测试 D. 验收测试,,,下列工具中属于需求分析常用工具的是( ),,A. PAD B. PFD,,C. N-S D. DFD,A,D,B,,3. 软件工程基础,,下面不属于软件设计原则的是( ),,A. 抽象 B. 模块化,,C. 自底向上 D. 信息隐蔽,,,在结构化方法中,软件功能分解属于下列软件开发中的阶段是( ),,A. 详细设计 B. 需求分析,,C. 总体设计 D. 编程调试,,,软件调试的目的是( ),,A. 发现错误 B. 改正错误,,C. 改善软件的性能 D. 挖掘软件的潜能,C,B,C,,3. 软件工程基础,,下列不属于软件调试技术的是( ),,A. 强行排错法 B. 集成测试法,,C. 回溯法 D. 原因排除法,,,下列叙述中,不属于软件需求规格说明书的作用的是( ),,A. 便于用户、开发人员进行理解和交流,,B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据,,C. 作为确认测试和验收的依据,,D. 便于开发人员进行需求分析,,,在数据流图(DFD)中,带有名字的箭头表示( ),,A. 控制程序的执行顺序 B. 模块之间的调用关系,,C. 数据的流向 D. 程序的组成成分,D,B,C,,3. 软件工程基础,,软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指( ),,A. 模块间的关系,,B. 系统结构部件转换成软件的过程描述,,C. 软件层次结构 D. 软件开发过程,,,为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为( ),,A. PAD图 B. N-S图,,C. 结构图 D. 数据流图,,,需求分析阶段的任务是确定( ),,A. 软件开发方法 B. 软件开发工具,,C. 软件开发费用 D. 软件系统功能,B,B,D,,3. 软件工程基础,,下列不属于结构化分析的常用工具的是( ),,A. 数据流图 B. 数据字典,,C. 判定树 D. PAD图,,,软件开发的结构化生命周期方法将软件生命周期划分成( ),,A. 定义、开发、运行维护,,B. 设计阶段、编程阶段、测试阶段,,C. 总体设计、详细设计、编程调试,,D. 需求分析、功能定义、系统设计,,,在软件工程中,白箱测试法可用于测试程序的内部结构。
此方法将程序看做是( ),,A. 循环的集合 B. 地址的集合,,C. 路径的集合 D. 目标的集合,A,D,C,,3. 软件工程基础,,若按功能划分,软件测试的方法通常分为白盒测试方法和______测试方法 (黑盒),,软件的调试方法主要有:强行。