《全国计算机二级公共基础.docx》由会员分享,可在线阅读,更多相关《全国计算机二级公共基础.docx(123页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、全国计算机二级公共基础附220题祥解二级公共基础知识新大纲基本要 求1,掌握算法的基本概念.2,掌握基本数据结构及其操作.3,掌握基本排序和查找算法.4掌握逐步求精的结构化程序设计方法.5,掌握软件工程的基本方法,具有初步应用相关技术进行软件开发的能 力.考试内容一,基本数据结构与算法1,算法的基本概念;算法复杂度的概 念和意义(时间复杂度与空间复杂度).2,数据结构的定义;数据的逻辑结构与存储结构;数据结构的图形表示; 线性结构与非线性结构的概念.3,线性表的定义;线性表的顺序存储结构及其插入与除运算.4,栈和队列的定义;栈和队列的顺序存储结构及其基本运算.5,线性单链表,双向链表与循环链表
2、的结构及其基本运算.6,树的基本概念;二*树的定义及其存储结构;二*树的前序,中序和后序 遍历.7,顺序查找与二分法查找算法;基本排序算法(交换类排序,选择类排序, 插入类排序).二,程序设计基础1,程序设计方法与风格.2,结构化程序设计.3,面向对象的程序设计方法,对象,方法,属性及继承与多态性.三,软件工程基础1,软件工程基本概念,软件声明周期概念,软件工具与 软件开发环境.2,结构化分析方法,数据流图,数据字典,软件需求规格说明书.3,结构化程序设计方法,总体设计与详细设计.4,软件测试的方法,白盒测试与黑盒测试,测试用例设计,软件测试的实施,单元测试,集成测试和系统测试.5,程序的调试
3、,静态调试与动态调试.四,数据库设计基础1,数据库的基本概念:数据库,数据库管理系统,数 据库系统.数据模型,实体练习模型及E-R图,从E-R图导出关系数据模型.2,关系代数运算,包括几何运算及选择,投影,连接运算,数据库规范化理 论.数据库设计方法和步骤:需求分析,概念设计,逻辑设计和物理设计的相关 策略.公共基础知识总结第一章数据结构与算法L1算法算法:是指解题方案 的准确而完整的描述.算法不等于程序,也不等计算机方法,程序的编制不可能优于算法的设计.算法的基本特征:是一组严谨地定义运算顺序的规则,每一个规则都是有 效的,是明确的,此顺序将在有限的次数下终止.特征包括:(1)可行性;(2)
4、确定性,算法中每一步骤都必须有明确定义,不充许有模棱 两可的解释,不允许有多义性;(3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义;(4)拥有足够的情算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构.指令系统:一个计算机系统能执行的所有指令的集合.基本运算和操作包括:算术运算,逻辑运算,关系运算,数据传输.算法的控制结构:顺序结构,选择结构,循环结构.算法基本设计方法:列举法,归纳法,递推,递归,减斗递推技术,回溯法.算法复杂度:算法时间复杂度和算法空间复杂度.算法时间复杂度是指执行算法所需要的计算工作量.(1)平均性态分析(2)最
5、坏情况复杂性算法空间复杂度是指执行这个算 法所需要的内存空间.如果额外空间量相对于问题规模来说是常数,则称该算法是原地工作的。1.2数据结构的基本基本概念数据结构研究的三个方面:(1)数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;(2) 在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结 构;(3)对各种数据结构进行的运算.数据结构是指相互有关联的数据元素的集合.(数据的逻辑结构、数据的 存储结构、对各种数据结构的运算)数据的逻辑结构包含:(1)表示数据元素的信息;(2)表示各数据元素之间的前后件关系.数据的存储结构有顺序,链接,索引等.线性结构条件:(1)有且只
6、有一个根结点;(2)每一个结点最多有一个前件,也最多有一个 后件.非线性结构:不满足线性结构条件的数据结构.1. 3线性表及其顺序存储结构线性表由一组数据元素构成,数据元素的位 置只取决于自己的序号,元素之间的相对位置是线性的.在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文件.非空线性表的结构特征:(1)且只有一个根结点al,它无前件;(2)有且只有一个终端结点an,它无 后件;(3)除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只 有一个后件.结点个数n称为线性表的长度,当n=0时,称为空表.线性表的顺序存储结构具有以下两个基本特点:(1
7、)线性表中所有元素的所占的存储空间是连续的;(2)线性表中各数据元 素在存储空间中是按逻辑顺序依次存放的.ai的存储地址为:ADR (ai)=ADR (al) + (i-l) k, ADR (al)为第一个元素的地 址,k代表每个元素占的字节数.顺序表的运算:插入,删除,查找,排序,分解,复制和逆转等操作.(详 见14-16页)1. 4栈和队列栈是限定在一端进行插入与删除的线性表,允许插 入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底.栈按照先进后出 (FILO)或后进先出 (LIFO)组织数据,栈具有记忆作用. 用top表示栈顶位置,用bottom表示栈底.栈的基本运算:(1)插入
8、元素称为入栈运算;(2)删除元素称为退栈运算;(3) 读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化.队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性 表.Rear指针指向队尾,front指针指向队头.队列是先进行出 (FIFO)或后进后出 (LILO)的线性表.队列运算包括(1)入队运算:从队尾插入一个元素;(2)退队运算:从队头删 除一个元素.循环队列:s=0表示队列空,s=l且front=rear表示队列满1. 5线性链表 数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点, 简称结点.结点由两部分组成:(1)用于存储数据元素值,称为数据域;
9、(2)用于存放指 针,称为指针域,用于指向前一个或后一个结点.在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的 存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系 是由指针域来确定的.链式存储方式即可用于表示线性结构,也可用于表示非线性结构.线性链表,HEAD称为头指针,HEAD=NULL (或0)称为空表,如果是两指针:左 指针(Llink)指向前件结点,右指针(Rlink)指向后件结点.线性链表的基本运算:查找,插入,删除.1. 6树与二叉树树是一种简单的非线性结构,所有元素之间具有明显的层 次特性.在树结构中,每一个结点只有一个前件,称为父结点,没有前件
10、的结点只有 一个,称为树的根结点,简称树的根.每一个结点可以有多个后件,称为该结点 的子结点.没有后件的结点称为叶子结点.在树结构中,一个结点所拥有的后件的个数称为该结点的度,所有结点中 最大的度称为树的度.树的最大层次称为树的深度.二叉树的特点:(1)非空二叉树只有一个根结点;(2)每一个结点最多有两 棵子树,且分别称为该结点的左子树与右子树.二叉树的基本性质:(1)在二叉树的第k层上,最多有2k-l(kl)个结点;(2)深度为m的二叉 树最多有2m-l个结点;(3)度为0的结点(即叶子结点)总是比度为2的结点多 一个;N=N0+Nl+N2N0=N2+l (4)具有n个结点的二叉树,其深度至
11、少为Elog2n+1, 其中log2n表示取log2n的整数部分;(5)具有n个结点的完全二叉树的深度 为log2n+l;(6)设完全二叉树共有n个结点.如果从根结点开始,按层序(每 一层从左到右)用自然数1, 2,.n给结点进行编号(k=l, 2.n),有以下结论:若k=l,则该结点为根结点,它没有父结点;若kl,则该结点的父结点编 号为INT(k/2);若2kWn,则编号为k的结点的左子结点编号为2k;否则该结 点无左子结点(也无右子结点);若2k+l Wn,则编号为k的结点的右子结点编 号为2k+l;否则该结点无右子结点.满二叉树是指除最后一层外,每一层上的所有结点有两个子结点,则k层
12、上有2k-l个结点深度为m的满二叉树有2m-1个结点.完全二叉树是指除最后一层外,每一层上的结点数均达到最大值,在最后 一层上只缺少右边的若干结点.二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层 序进行顺序存储.二叉树的遍历:ABC(l)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;(2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子 树;(3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结 点.1.7查找技术顺序查找的使用情况:(1)线性表为无序表;(2)表采用链式存储结构.二分法查找只适用于顺序存储的有序表,对于
13、长度为n的有序线性表,最 坏情况只需比较log2n次.1. 8排序技术排序是指将一个无序序列整理成按值非递减顺序排列的有 序序列.交换类排序法:冒泡排序法,需要比较的次数为n(n-1)/2; (2)快速排 序法.插入类排序法:(1)简单插入排序法,最坏情况需要n(n-l)/2次比较;(2) 希尔排序法,最坏情况需要0(nl. 5)次比较.选择类排序法:(D简单选择排序法,最坏情况需要n(n-1)/2次比较;(2) 堆排序法,最坏情况需要0(nlog2n)次比较.第二章程序设计基础2. 1程序设计设计方法和风格HRBJGD163. COM如 何形成良好的程序设计风格1,源程序文档化;2,数据说明
14、的方法;3,语句的结 构;4,输入和输出.注释序言性注释和功能性注释,语句结构清晰第一,效率第二.1.2 结构化程序设计结构化程序设计方法的四条原则是:1.自顶向下 逐步求精;3.模块化;4.限制使用goto语句.结构化程序的基本结构和特点:(1)顺序结构:一种简单的程序设计,最基本,最常用的结构;(2)选择结构: 又称分支结构,包括简单选择和多分支选择结构,可根据条件,判断应该选择哪 一条分支来执行相应的语句序列;(3)重复结构:又称循环结构,可根据给定条 件,判断是否需要重复执行某一相同程序段.1.3 面向对象的程序设计面向对象的程序设计:以60年代末挪威奥斯陆 大学和挪威计算机中心研制的
15、SIMULA语言为标志.面向对象方法的优点:(1)与人类习惯的思维方法一致;(2)稳定性好;(3)可重用性好;(4)易于开 发大型软件产品;(5)可维护性好.对象是面向对象方法中最基本的概念,可以用来表示客观世界中的任何实 体,对象是实体的抽象.面向对象的程序设计方法中的对象是系统中用来描述客观事物的一个实 体,是构成系统的一个基本单位,由一组表示其静态特征的属性和它可执行的 一组操作组成.属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法 或服务.对象的基本特点:(1)标识惟一性;(2)分类性;(3)多态性;(4)封装性;(5)模块独立性好.类是指具有共同属性,共同方法的对象的
16、集合.所以类是对象的抽象,对象 是对应类的一个实例.消息是一个实例与另一个实例之间传递的信息.消息的组成包括接收消息的对象的名称;(2)消息标识符,也称消息 名;(3)零个或多个参数.继承是指能够直接获得已有的性质和特征,而不必重复定义他们.继承分单继承和多重继承.单继承指一个类只允许有一个父类,多重继承 指一个类允许有多个父类.多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现 象.第三章软件工程基础3.1软件工程基本概念计算机软件是包括程序,数 据及相关文档的完整集合.软件的特点包括:(1)软件是一种逻辑实体;(2)软件的生产与硬件不同,它没有明显的制作 过程;(3)软件在运行
17、,使用期间不存在磨损,老化问题;(4)软件的开发,运行对 计算机系统具有依赖性,受计算机系统的限制,这导致了软件移植的问题;(5) 软件复杂性高,成本昂贵;(6)软件开发涉及诸多的社会因素.软件按功能分为应用软件,系统软件,支撑软件(或工具软件).软件危机主要表现在成本,质量,生产率等问题.软件工程是应用于计算机软件的定义,开发和维护的一整套方法,工具,文 档,实践标准和工序.软件工程包括3个要素:方法,工具和过程.软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4 种基本活动:(DP一一软件规格说明;(2)D软件开发;(3)C 软件确认;(4)A 软件演进.软件周期:软件产品从
18、提出,实现,使用维护到停止使用退役的过程.软件生命周期三个阶段:软件定义,软件开发,运行维护,主要活动阶段是:(1)可行性研究与计划制定;(2)需求分析;(3)软件设计;(4)软件实现;(5) 软件测试;(6)运行和维护.软件工程的目标和与原则:目标:在给定成本,进度的前提下,开发出具有有效性,可靠性,可理解性, 可维护性,可重用性,可适应性,可移植性,可追踪性和可互操作性且满足用户 需求的产品.基本目标:付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能按时完成开发,及时交付使用.软件工程的理论和技术性研究的内容主要包括:软件开发技术和软件工程
19、管理.软件开发技术包括:软件开发方法学,开发过程,开发工具和软件工程环 境.软件工程管理包括:软件管理学,软件工程经济学,软件心理学等内容.软件管理学包括人员组织,进度安排,质量保证,配置管理,项目计划等.软件工程原则包括抽象,信息隐蔽,模块化,局部化,确定性,一致性,完备 性和可验证性.3. 2结构化分析方法结构化方法的核心和基础是结构化程序设计理论.需求分析方法有(1)结构化需求分析方法;(2)面向对象的分析的方法.从需求分析建立的模型的特性来分:静态分析和动态分析.结构化分析方法的实质:着眼于数据流,自顶向下,逐层分解,建立系统的 处理流程,以数据流图和数据字典为主要工具,建立系统的逻辑
20、模型.结构化分析的常用工具(1)数据流图;(2)数据字典;(3)判定树;(4)判定 表.数据流图:描述数据处理过程的工具,是需求理解的逻辑模型的图形表示, 它直接支持系统功能建模.数据字典:对所有与系统相关的数据元素的一个有组织的列表,以及精确 的,严格的定义,使得用户和系统分析员对于输入,输出,存储成分和中间计算 结果有共同的理解.判定树:从问题定义的文字描述中分清哪些是判定的条件,哪些是判定的 结论,根据描述材料中的连接词找出判定条件之间的从属关系,并列关系,选择 关系,根据它们构造判定树.判定表:与判定树相似,当数据流图中的加工要依赖于多个逻辑条件的取 值,即完成该加工的一组动作是由于某
21、一组条件取值的组合而引发的,使用判 定表描述比较适宜.数据字典是结构化分析的核心.软件需求规格说明书的特点:(1)正确性;(2)无岐义性;(3)完整性;(4)可验证性;(5) 一致性;(6)可理 解性;(7)可追踪性.3. 3结构化设计方法软件设计的基本目标是用比较抽象概括的方式确定 目标系统如何完成预定的任务,软件设计是确定系统的物理模型.软件设计是开发阶段最重要的步骤,是将需求准确地转化为完整的软件产 品或系统的唯一途径.从技术观点来看,软件设计包括软件结构设计,数据设计,接口设计,过程 设计.结构设计:定义软件系统各主要部件之间的关系.数据设计:将分析时创建的模型转化为数据结构的定义.接
22、口设计:描述软件内部,软件和协作系统之间以及软件与人之间如何通 信.过程设计:把系统结构部件转换成软件的过程描述.从工程管理角度来看:概要设计和详细设计.软件设计的一般过程:软件设计是一个迭代的过程;先进行高层次的结构 设计;后进行低层次的过程设计;穿插进行数据设计和接口设计.衡量软件模块独立性使用耦合性和内聚性两个定性的度量标准.在程序结构中各模块的内聚性越强,则耦合性越弱.优秀软件应高内聚,低 耦合.软件概要设计的基本任务是:(1)设计软件系统结构;(2)数据结构及数据库设计;(3)编写概要设计文 档;(4)概要设计文档评审.模块用一个矩形表示,箭头表示模块间的调用关系.在结构图中还可以用
23、带注释的箭头表示模块调用过程中来回传递的信息. 还可用带实心圆的箭头表示传递的是控制信息,空心圆箭头表示传递的是数 据.结构图的基本形式:顺序形式,重复形式,选择形式.结构图有四种模块类型:传入模块,传出模块,变换模块和协调模块.典型的数据流类型有两种:变换型和事务型.变换型系统结构图由输入,中心变换,输出三部分组成.事务型数据流的特点是:接受一项事务,根据事务处理的特点和性质,选择 分派一个适当的处理单元,然后给出结果.详细设计:是为软件结构图中的每一个模块确定实现算法和局部数据结构, 用某种选定的表达工具表示算法和数据结构的细节.常见的过程设计工具有:图形工具(程序流程图、NS、PAD、H
24、IPO),表格 工具(判定表),语言工具(PDL).程序流程图是一种传统的、应用广泛的软件过程设计表示工具,也称程序 框图。控制流逻辑条件加工步骤程序流程图特点:简单易学,但不受约束,随意转移控制,会破坏结构化设计的原则,且不易表示数据 结构NS图:方框图。特征1.每个构件具有明确的功能域。2.控制转移必须遵守结构化设计要求3.易于确定局部数据和全局数据的作用域。4.易于表达嵌套关系和模块的层次结构PAD图:特征1.结构清晰,结构 化程序高2.易于阅读3.最左端的纵线是程序主干线,对应程序的第一层结构; 每增加一层PAD图向右扩展一个纵线,即纵线条数等于程序的层次数。4.程序执行时,从PAD图
25、最左主干线上端结点开始,自上向下,自左向右 依次执行,程序终止于最左主干线PDL过程设计语言,也称结构化的英语和 伪码。1有为结构化构成元素,数据说明和模块化特征提供的关键词语法2.处 理部分的描述采用自然语言语法3.可能说明简单和复杂的数据结构4.支持各 种接口描述的子程序定义和调用技术3.4软件测试软件测试定义:使用人工 或自动手段来运行或测定某个系统的过程,其目的在于检验它是否满足规定的 需求或是弄清预期结果与实际结果之间的差别.软件测试的目的:发现错误而执行程序的过程.软件测试方法:静态测试和动态测试.静态测试包括代码检查,静态结构分析,代码质量度量.不实际运行软件, 主要通过人工进行
26、.动态测试:是基本计算机的测试,主要包括白盒测试方法和黑盒测试方法.白盒测试(结构测试或逻辑驱动测试):在程序内部进行,主要用于完成软 件内部操作的验证.主要方法有逻辑覆盖,基本路径测试.逻辑覆盖:指一系列以程序内部的逻辑结构为基础的测试用例设计技术。 通常指程度中的逻辑表示有判断、分支、条件等几种表示方式。1语句覆盖:选择足够的测试用例,使得程序中每个语句至少被执行一次。2 .路径覆盖:执行足够的测试用例,使程序中所有可能的路径至少经历一 次。3 .判断覆盖:使设计的测试用例保证程序中每个判断的每个取值分支至少 经历一次4.条件覆盖:设计的测试用例保证程序中每个判断的每个条件的可 能取值至少
27、执行一次。5.判断一一条件覆盖:设计足够的测试用例,使判断中每个条件的所有可 能取值至少执行一次,同时每个判断的所有可能取值分支至少执行一次。基本路径测试:根据软件过程性描述中的控制流程确定程序的环路复杂性 度量,用此度量定义基本路径集合,并由此导出一组测试用例,对每一条独立 执行路径进行测试。黑盒测试(功能测试或数据驱动测试):墨盒测试是对软件已试验的功能 是否满足需要进行测试和验证。主要诊断功能不对或遗漏,界面错误,数据结构 或外部数据库访问错误,性能错误,初始化和终止条件错,用于软件确认.主要 方法有等价类划分法,边界值分析法,错误推测法,因果图等.等价类划分法:是一种典型的黑盒测试方法
28、。是将程序的所有可能的输入 数据划分成若干部分,然后从每个等价类中选取数据作为测试用例。包括1 有效等价类:合理、有意义的输入数据构成的集合,检验程序中符合规定的功 能和性能2无效等价类:不合理、无意义的输入数据构成的集合,可以检验程 序中符合规定的功能和性能。边界值分析法:对各种输入、输出范围的边界情况设计测试用例的方法。程序错误最容易出现在输入或输出范围的边界处。错误推测法:以经验和直觉推测程序中可能存在的各种错误,有针对性地 编写检查这些错误的例子。基本想法是:列举出程序中所有可能出现的错误和容易发生错误的特殊情 况,根据它们选择测试用例。软件测试过程一般按4个步骤进行:单元测试,集成测
29、试,验收测试(确认 测试)和系统测试.1单元测试 是对软件设计的最小单位模块进行正确性检测的过程,其目 的是发现一个模块内部可能存在的各种错误。依据:详细设计说明书和源程序O 动态测试以白盒测试为主,辅之以黑盒测试。单元测试主要针对模块的五个基本特性进行:(1模块接口测试:测试通过模块的数据流(2局部数据结构测试:检查 局部数据一致性、数据的初始化、数据类型的一致以及数据的下溢,上溢。(3重要的执行路径的检查(4出错处理测试:检查模块的错误处理功能 (5影响以上各点及其他相关点的边界条件测试2集成测试是测试和组装软件 的过程。主要目的是发现与结构有关的错误。集成测试的依据是概要计算机说明书。集
30、成测试涉及的内容包括软件单元的接口测试、全局数据结构测试、边界 条件和非法输入的测试等。集成测试时将模块组成程序通常采用两种方式:非增量方式组装(一次性 组装)与增量方式组装(自顶向下、自底向上以及自顶向下和自底向上结合)。3验收测试任务是验证软件的功能和性能及其他特性是否满足了规格 说明书中确定的各种需求,软件配置是否完全、正确首先运用黑盒测试方法对 软件进行有效性测试工,然后通过复审保证软件配置齐全,分类有序以及软件 配置所有的成分的完备性、一致性、准确性和可操作性。4系统测试是将通过测试的软件作为整个基于计算机系统的一个元素,与 计算机硬件、外设、支持软件、数据和人员等其他系统元素组合在
31、一起,在实 际运行环境下对计算机系统进行集成测试和确认测试。系统测试必须在目标环 境下运行,其功能在于评估系统环境下软件的性能,发现和捕捉软件中潜在的 错误。目的是在真实的系统工作环境下检验软件是否能与系统正确连接,发现软 件与系统需求不一致的地方。包括:功能测试、性能测试、操作测试、配置测试、外部接口测试和安全 性测试。软件测试贯穿整个软件的生存期。3. 5程序的调试程序调试的任务是诊断和改正程序中的错误,主要在开发 阶段进行.程序调试分两部分:根据错误的迹象确定程序中错误的性质、原因和位置;对程序进行修改,排除这个错误。程序调试的基本步骤:(1)错误定位;(2)修改设计和代码,以排除错误;
32、(3)进行回归测试,防止引 进新的错误.程序调试的原则:1确定错的性质和出错位置时注意事项2修改错误的原 则 在出现错误的地方,可能有别的错误;改正错误只修改了这个错误的表现, 而没有改正错误本身;改正错误的同时引入新的错误;改正错误的过程是回到 程序设计阶段;修改源代码程序,不要改变目标代码。软件调试可分表静态调试和动态调试.静态调试主要是指通过人的思维来 分析源程序代码和排错,是主要的设计手段,而动态调试是辅助静态调试.主要 调试方法有:(1)强行排错法;(2)回溯法;(3)原因排除法.4.1数据库系统的基本概念数据:实际上就是描述事物的符号记录.数据的特点:有一定的结构,有型与值之分,如
33、整型,实型,字符型等.而数 据的值给出了符合定型的值,如整型值15.数据库:是数据的集合,具有统一的结构形式并存放于统一的存储介质内, 是多种应用数据的集成,并可被各个应用程序共享.数据库存放数据是按数据所提供的数据模式存放的,具有集成与共享的特 点 /、数据库管理系统:一种系统软件,负责数据库中的数据组织,数据操纵,数 据维护,控制及保护和数据服务等,是数据库的核心.数据库管理系统功能:(1)数据模式定义:即为数据库构建其数据框架;(2)数据存取的物理构建: 为数据模式的物理存取与构建提供有效的存取方法与手段;(3)数据操纵:为用 户使用数据库的数据提供方便,如查询,插入,修改,删除等以及简
34、单的算术运 算及统计;(4)数据的完整性,安生性定义与检查;(5)数据库的并发控制与故障 恢复;(6)数据的服务:如拷贝,转存,重组,性能监测,分析等.为完成以上六个功能,数据库管理系统提供以下的数据语言:(1)数据定义语言:负责数据的模式定义与数据的物理存取构建;(2)数据 操纵语言:负责数据的操纵,如查询与增,删,改等;(3)数据控制语言:负责数据 完整性,安全性的定义与检查以及并发控制,故障恢复等.数据语言按其使用方式具有两种结构形式:交互式命令(又称自含型或自 主型语言)宿主型语言(一般可嵌入某些宿主语言中).数据库管理员DBA:对数据库进行规划,设计,维护,监视等的专业管理人 员.工
35、作:数据库设计、数据库维护、改善系统性能。数据库系统DBS:由数据库(数据),数据库管理系统(软件),数据库管理员 (人员),硬件平台(硬件),软件平台(软件)五个部分构成的运行实体.数据库应用系统DBAS:由数据库系统,应用软件及应用界面三者组成.数据库管理系统DBMS数据库系统发展三个阶段:文件系统阶段:提供了简单的数据共享与数据管理能力,但是它无法提供 完整的,统一的,管理和数据共享的能力.层次数据库与网状数据库系统阶段:为统一与共享数据提供了有力支撑.关系数据库系统阶段数据库系统的基本特点:数据的集成性,数据的高共 享性与低冗余性,数据独立性(物理独立性与逻辑独立性),数据统一管理与控
36、 制.物理独立性:是数据的物理结构包括存储结构、存取方式的改变为,不影 响数据库的逻辑结构。逻辑独立性:数据库总体逻辑结构的改变如修改数据、增加数据类型等, 不需要相应修改应用程序。数据的统一管理与控制1数据的完整性检查2数据的安全性保护3并发 控制数据库系统的三级模式:(1)概念模式:数据库系统中全局数据逻辑结构的描述,全体用户公共数据 视图;外模式:也称子模式或用户模式.是用户的数据视图,也就是用户所见 到的数据模式;内模式:又称物理模式,它给出了数据库物理存储结构与物 理存取方法.内模式处于最底层,反映了数据在计算机物理结构中的实际存储形式;概 念模式处于中层,反映了设计者的数据全局逻辑
37、要求;处模式处于最外层,反 映了用户对数据的要求。数据库系统的两级映射:(1)概念模式到内模式的映射;(2)外模式到概念模式的映射.4. 2数据模型数据模型的概念:是数据特征的抽象,从抽象层次上描述了 系统的静态特征,动态行为和约束条件,为数据库系统的信息表与操作提供一 个抽象的框架.描述了数据结构,数据操作及数据约束.E-R模型的基本概念实体:现实世界中的事物;(2)属性:事物的特 性;(3)联系:现实世界中事物间的关系.实体集的关系有一对一,一对多,多对多的联系.E-R模型三个基本概念之间的联接关系:实体是概念世界中的基本单位, 属性有属性域,每个实体可取属性域内的值.一个实体的所有属性值
38、叫元组.E-R模型的图示法:(1)实体集表示法;(2)属性表法;(3)联系表示法.层次模型的基本结构是树形结构,具有以下特点:(1)每棵树有且仅有一个无双亲结点,称为根;(2)树中除根外所有结点有 且仅有一个双亲.网状模型从图论上看,网状模型是一个不加任何条件限制的无向图.关系模型采用二维表来表示,简称表,由表框架及表的元组组成.一个二维 表就是一个关系.在二维表中凡能唯一标识元组的最小属性称为键或码.从所有侯选健中选 取一个作为用户使用的键称主键.表A中的某属性是某表B的键,则称该属性集 为A的外键或外码.关系中的数据约束:(1)实体完整性约束:约束关系的主键中属性值不能为空值;(2)参照完
39、全 性约束:是关系之间的基本约束;(3)用户定义的完整性约束:它反映了具体应 用中数据的语义要求.4. 3关系代数关系数据库系统的特点之一是它建立在数据理论的基础之 上,有很多数据理论可以表示关系模型的数据操作,其中最为着名的是关系代 数与关系演算.关系模型的基本运算:(1)插入(2)删除(3)修改(4)查询(包括投影,选择,笛卡尔积运算)4. 4 数据库设计与管理数据库设计是数据应用的核心.数据库设计的两种方法:(1)面向数据:以信息需求为主,兼顾处理需求;(2)面向过程:以处理需求 为主,兼顾信息需求.数据库的生命周期:需求分析阶段,概念设计阶段,逻辑设计阶段,物理设 计阶段,编码阶段,测
40、试阶段,运行阶段,进一步修改阶段.需求分析常用结构析方法和面向对象的方法.结构化分析(简称SA)方法用自顶向下,逐层分解的方式分析系统.用数据 流图表达数据和处理过程的关系.对数据库设计来讲,数据字典是进行详细的 数据收集和数据分析所获得的主要结果.数据字典是各类数据描述的集合,包括5个部分:数据项,数据结构,数据 流(可以是数据项,也可以是数据结构),数据存储,处理过程.数据字典是在需求分析阶段建立、在数据库设计过程中完善的数据库概念 设计的目的是分析数据内在语义关系.设计的方法有两种(1)集中式模式设计 法(适用于小型或并不复杂的单位或部门);(2)视图集成设计法.设计方法:E-R模型与视
41、图集成.视图设计一般有三种设计次序:自顶向下,由底向上,由内向外.视图集成的几种冲突:命名冲突,概念冲突,域冲突,约束冲突.数据库的逻辑设计1从E-R图向关系模式转换。2逻辑模式规范化及调整、实现3关系视图设计关系视图设计:关系视图的设计又称外模式设计.关系视图的主要作用:(1)提供数据逻辑独立性;(2)能适应用户对数据的不同需求;(3)有一定数 据保密功能.数据库的物理设计主要目标是对数据内部物理结构作调整并选择合理的 存取路径,以提高数据库访问速度有效利用存储空间.一般RDBMS中留给用户 参与物理设计的内容大致有索引设计,集成簇设计和分区设计.数据库管理的内容:(1)数据库的建立;(2)
42、数据库的调整;(3)数据库的重组;(4)数据库安全性 与完整性控制;(5)数据库的故障恢复;(6)数据库监控.附件一:国家二级基础知识题库及分析(1)栈和队列的共同特点是DA)都 是先进先出B)都是先进后出C)只允许在端点处插入和删除元素D)没有共同 点解析:栈和队列都是一种特殊的操作受限的线性表,只允许在端点处进行插 入和删除.二者的区别是:栈只允许在表的一端进行插入或删除操作,是一种 后进先出的线性表;而队列只允许在表的一端进行插入操作,在另一端进行删 除操作,是一种先进先出的线性表.所以没有共同点(2)已知二叉树后序遍历 序列是dAbec,中序遍历序列是debac,它的前序遍历序列是DC
43、ED BAA) acbed B) decab C) deabc D) cedba 解析:依据后序遍历序列可 确定根结点为c;再依据中序遍历序列可知其左子树由deba构成,右子树为空; 又由左子树的后序遍历序列可知其根结点为e,由中序遍历序列可知其左子树 为d,右子树由ba构成,如下图所示.求得该二叉树的前序遍历序列为选项D).(3)链表不具有的特点是BA)不必事先估计存储空间B)可随机访问任一 元素C)插入删除不需要移动元素D)所需空间与线性表长度成正比解析:链 表采用的是链式存储结构,它克服了顺序存储结构的缺点:它的结点空间可以 动态申请和释放;它的数据元素的逻辑次序靠结点的指针来指示,不需
44、要移动 数据元素.但是链式存储结构也有不足之处: 每个结点中的指针域需额外占 用存储空间;链式存储结构是一种非随机存储结构.(4)结构化程序设计的3种结构是DA)顺序结构,选择结构,转移结构B) 分支结构,等价结构,循环结构C)多分支结构,赋值结构,等价结构D)顺序结 构,选择结构,循环结构解析:顺序结构,选择结构和循环结构(或重复结构)是 结构化程序设计的3种基本结构.(5)为了提高测试的效率,应该DA)随机选取测试数据B)取一切可能的输 入数据作为测试数据C)在完成编码以后制定软件的测试计划D)集中对付那 些错误群集的程序解析:测试的目的是发现软件中的错误.经验表明,程序中 存在错误的概率
45、与该程序中已发现的错误数成正比.这一现象说明,为了提高 测试效率,测试人员应该集中对付那些错误群集的程序.(6)算法的时间复杂度是指CA)执行算法程序所需要的时间B)算法程序 的长度C)算法执行过程中所需要的基本运算次数D)算法程序中的指令条数 解析:算法的复杂度主要包括算法的时间复杂度和算法的空间复杂度.所谓算 法的时间复杂度是指执行算法所需要的计算工作量;算法的空间复杂度一般是 指执行这个算法所需要的内存空间.(7)软件生命周期中所花费用最多的阶段是DA)详细设计B)软件编码C) 软件测试D)软件维护解析:软件生命周期分为软件定义,软件开发及软件运 行维护3个阶段.本题中,详细设计,软件编
46、码和软件测试都属于软件开发阶段; 维护是软件生命周期的最后一个阶段,也是持续时间最长,花费代价最大的一 个阶段,软件工程学的一个目的就是提高软件的可维护性,降低维护的代价.(8)数据库管理系统DBMS中用来定义模式,内模式和外模式的语言为 CA)C B) Basic C)DDL D)DML解析:选项A), B)显然不合题意.数据定义语言 (Data Definition Language,简称DDL)负责数据的模式定义与数据的物理存 取构建;数据操纵语言(Data Manipulation Language,简称DML)负责数据的操 纵,包括查询及增,删,改等操作.(9)下列有关数据库的描述,
47、正确的是CA)数据库是一个DBF文件B)数据 库是一个关系C)数据库是一个结构化的数据集合D)数据库是一组文件解析: 数据库(Database,简称DB)是数据的集合,它具有统一的结构形式并存放于统 一的存储介质内,是多种应用数据的集成,并可被各个应用程序所共享.数据库 中的数据具有集成,共享之特点.(10)下列有关数据库的描述,正确的是DA)数据处理是将信息转化为数据 的过程B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构 不变C)关系中的每一列称为元组,一个元组就是一个字段D)如果一个关系中 的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为 本关系的外关键字解析:数据处理是指将数据转换成信息的过程,故选项A) 叙述错误;数据的物理独立性是指数据的物理结构的改变,不会影响数据库的 逻辑结构,故选项B)叙述错误;关系中的行称为元组,对应存储文件中的记录, 关系中的列称为属性,对应存储文件中的字段,故选项C)叙述错误.填空题(1)算法的基本特征是可行性,确定性,【1】和拥有足够的情报. 答案:有穷性解析:算法是指解题方案的准确而完整的描述.它有4个基本特 征,分别是可行性,确定性,有穷性和拥有足够的情报.(2)在长度为n的有序线性表中进行二分查找.最坏的情况下,需要的比较 次数为【2】.答案:log2n解析:对于长度为n的有序线性表,在最坏情况下,
限制150内