1、12008年4月真题1.程序流程图中带有箭头的线段表示的是_。A)图元关系 B)数据流C)控制流 D)调用关系参考答案:C【解析】程序流程图是人们对解决问题的方法、思路或算法的一种描述。其中,图框表示各种操作的类型,图框中的文字和符号表示操作的内容,流程线表示操作的先后次序。带箭头的线段在数据流程图中表示数据流,而在程序流程图中表示控制流。在所给出的选项中,在图元之间用带有箭头的线段表示图元关系。在模块之间用带有箭头的线段表示调用关系。构成程序流程图的基本图符及其含义是:或表示控制流;表示加工步骤;表示逻辑条件。2. 结构化程序设计的基本原则不包括_。A)多态性 B)自顶向下C)模块化 D)逐
2、步求精参考答案:A【解析】结构化程序设计的原则包括:“自顶而下,逐步求精“的设计思想,“独立功能,单出口、单入口“的模块化设计等。多态性是面向对象程序语言的特征。3.软件设计中模块划分应遵循的准则是_。A)低内聚低耦合 B)高内聚低耦合C)低内聚高耦合 D)高内聚高耦合参考答案:B【解析】模块划分应遵循的准则包括模块之间的耦合和内聚。一般来说,要求模块之间的耦合尽可能地低,即模块尽可能独立,要求模块的内聚程度尽可能地高,即高内聚、低耦合的原则。4.在软件开发中,需求分析阶段产生的主要文档是_。A)可行性分析报告 B)软件需求规格说明书C)概要设计说明书 D)集成测试计划参考答案:B【解析】需求
3、分析阶段的工作主要包括需求获取、需求分析、编写需求规格说明书和需求评审等四方面。产生的主要文档为软件需求规格说明书,它可以为用户、分析人员和设计人员之间的交流提供方便,可以直接支持目标软件系统的确认,又可以作为控制软件开发进程的依据。5.算法的有穷性是指_。A)算法程序的运行时间是有限的B)算法程序所处理的数据量是有限的C)算法程序的长度是有限的D)算法只能被有限的用户使用参考答案:A【解析】算法具有6个特性。 有穷性:一个算法必须总是(对任何合法的输入值)在执行有穷步之后结束,且每一步都可在有限时间内完成,即运行时间是有限的。 确定性:算法中每一条指令必须有确切的含义,读者理解时不会产生歧义
4、。 可行性:一个算法是可行的,即算法中描述的操作都是可以通过已经实现的基本运算执行有限次来实现。 输入:一个算法有零个或多个输入,这些输入取自某个特定的对象的集合。 输出:一个算法有一个或多个输出。26.对长度为n的线性表排序,在最坏情况下,比较次数不是n(n1)/2的排序方法是_。A)快速排序 B)冒泡排序C)直接插入排序 D)堆排序参考答案:D【解析】在最坏情况下,快速排序、冒泡排序和直接插入排序需要的比较次数都是n(n1)/2,堆排序需要比较的次数为nlog2n。7.下列关于栈的叙述正确的是_。A)栈按“先进先出“组织数据B)栈按“先进后出“组织数据C)只能在栈底插入数据D)不能删除数据
5、参考答案:B【解析】在栈中,允许插入与删除的一端称为栈顶,而不允许插入与删除的一端称为栈底。栈顶元素总是最后被插入的元素,从而也是最先被删除的元素;栈底元素总是最先被插入的元素,从而也是最后才能被删除的元素。因而栈是按照“先进后出“或“后进先出“的原则组织数据的。8.在数据库设计中,将ER图转换成关系数据模型的过程属于_。A)需求分析阶段 B)概念设计阶段C)逻辑设计阶段 D)物理设计阶段参考答案:C【解析】数据库的逻辑设计分为: 将概念模型转换成一般的数据模型; 将一般的数据模型转换为特定的数据库管理系统所支持的数据模型。把概念模型转换成关系数据模型就是把ER图转换成一组关系模式。9.有三个
6、关系R、S和T如下:RB C Da 0 k1b 1 n1SB C Df 3 h2a 0 k1n 2 x1TB C Da 0 k1由关系R和S通过运算得到关系T,则所使用的运算为_。A)并 B)自然连接C)笛卡尔积 D)交参考答案:D【解析】在关系运算中,交的定义如下:设R1和R2为参加运算的两个关系,它们具有相同3的度n,且相对应的属性值取自同一个域,则R1R2为交运算,结果仍为度等于n的关系,其中,交运算的结果既属于R1又属于R2。10.设有表示学生选课的三张表,学生S(学号,姓名,性别,年龄,身份证号),课程C(课号,课名),选课SC(学号,课号,成绩),则表SC的关键字(键或码)为_。A
7、)课号,成绩B)学号,成绩C)学号,课号D)学号,姓名,成绩参考答案:C【解析】“选课 SC“ 表是 “学生 S“ 表和 “课程 C“ 表的映射表,主键是两个表主键的组合。11.以下叙述中正确的是A)C程序中的注释只能出现在程序的开始位置和语句的后面B)C程序书写格式严格,要求一行内只能写一个语句C)C程序书写格式自由,一个语句可以写在多行上D)用C语言编写的程序只能放在一个程序文件中参考答案:C【解析】在C语言中,注释可以加在程序中的任何位置,选项A)错误。C程序可以分模块写在不同的文件中,编译时再将其组合在一起,选项D)错误。C程序的书写风格很自由,不但一行可以写多个语句,还可以将一个语句
8、写在多行中。所以正确答案为选项C)。12.以下选项中不合法的标识符是A)print B)FOR C)B)char A651,bb;C)float a1,*bD)double a0.0;b1.1;参考答案:B【解析】本题考查变量的定义方法。如果要一次进行多个变量的定义,则在它们之间要用逗号隔开。因此选项A)和D)错误;在选项C)中,变量c是一个浮点型指针,它只能指向一个浮点型数据,不能指向指针变量b;所以正确答案为B)。16. 有以下程序段:char ch;int k;cha;k12;printf(“%c,%d,“,ch,ch,k);printf(“k%dn“,k);已知字符a的ASCII码值为
9、97,则执行上述程序段后输出结果是A)因变量类型与格式描述符的类型不匹配输出无定值B)输出项与格式描述符个数不符,输出为零或不定值C)a,97,12k12D)a,97,k12参考答案:D【解析】输出格式控制符%c表示将变量以字符的形式输出;输出格式控制符%d表示将变量以带符号的十进制整型数输出。所以第一个输出语句输出的结果为a,97,第二个输出语句输出的结果为k12,所以选项D)为正确答案。17.已知字母A的ASCII码值为65,若变量kk为char型,以下不能正确判断出kk中的值为大写字母的表达式是A)kkA B)scanf(“%s“,s1);C)gets(s); D)scanf(“%s“,
10、s1);参考答案:D【解析】在格式输入中,要求给出的是变量的地址,而D)答案中给出的s1是一个值的表达式。28.以下叙述中错误的是A)在程序中凡是以“#“开始的语句行都是预处理命令行B)预处理命令行的最后不能以分号表示结束C)#define MAX是合法的宏定义命令行D)C程序对预处理命令行的处理是在程序执行的过程中进行的参考答案:D【解析】C语言中的预处理命令以符号#开头,这些命令是在程序编译之前进行处理的,选项D)的描述错误。故答案选D)。29.以下结构体类型说明和变量定义中正确的是A)typedef structint n; char c;REC;REC t1,t2;B)struct R
11、EC;8int n; char c;REC t1,t2;C)typedef struct REC ;int n=0; char c=A;t1,t2;D)structint n; char c;REC;REC t1,t2;参考答案:A【解析】本题考查的是typedef的用法和结构体变量的定义方法。typedef可用于声明结构体类型,其格式为“typedef struct 结构元素定义结构类型;“。本题正确答案为A)。30.以下叙述中错误的是A)gets函数用于从终端读入字符串B)getchar函数用于从磁盘文件读入字符C)fputs函数用于把字符串输出到文件D)fwrite函数用于以二进制形式输
12、出数据到文件参考答案:B【解析】getchar函数的作用是从终端读入一个字符。31.有以下程序:#include main() int s121,2,3,4,4,3,2,1,1,1,2,3,c50,i;for(i0;ivoid fun(int *s,int n1,int n2) int i,j,t;in1; jn2;while(i#include void fun(char *s,int n) char *t; int i,j;for(i0;istrlen(sj) tsi;si=sj;sjt;main() char *ss“bcc“,“bbcc“,“xy“,“aaaacc“,“aabcc“;f
13、un(ss,5); printf(“%s,%sn“,ss0,ss4);程序的运行结果是A)xy,aaaacc B)aaaacc,xyC)bcc,aabcc D)aabcc,bcc参考答案:A【解析】函数fun(char *s,int n)的功能是对字符串数组的元素按照字符串的长度从小到大排序。在主函数中执行fun(ss,5)语句后,*ss“xy“, “bcc“, “bbcc“, “aabcc“, “aaaacc“,ss0,ss4的输出结果为xy,aaaacc。所以选项A)为正确答案。34.有以下程序:#include int f(int x) int y;if(x0|x1) return(3)
14、;yx*xf(x2);return y;main() int z;zf(3); printf(“%dn“,z);10程序的运行结果是A)0 B)9C)6 D)8参考答案:C【解析】函数int f(int x)是一个递归函数调用,当x的值等于0或1时,函数值等于3,其他情况下yx2f(x2)。所以在主函数中执行语句“zf(3)“时,y3*3-f(3-2)=9-f(1)=6。35.有以下程序:#include void fun(char *a,char *b) while(*a*)a;while(*b*a)b;a;main() char *s“*a*b*“,t80;fun(s,t); puts(t
15、);程序的运行结果是A)*a*b B)a*bC)a*b* D)ab参考答案:C【解析】在函数fun(char *a,char *b)中,while(*a*)a的功能是:如果*a的内容为*,则a指针向后移动,直到遇到非*字符为止,退出循环进入下一个while循环,在while(*b*a)b;a;中,把字符数组a中的字符逐个赋给字符数组b。所以在主函数中,执行fun(s,t)语句后,字符数组t中的内容为“a*b*“。所以选项C)为正确答案。36.有以下程序:#include #include typedef struct char name9; char sex; float score2; ST
16、U;void f(STU a) STU b“Zhao“,m,85.0,90.0; int i;strcpy(a.name,b.name);asexb.sex;for(i0;imain() FILE *fp; int a101,2,3,i,n;fpfopen(“d1.dat“,“w“);for(i0;imain() int x1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,*p4,i;for(i0;ivoid swap(int *a, int *b) int *t;ta; ab; bt;main() int i3,j5,*p 所以 。4.下列叙述中正确的是_。A)
17、顺序存储结构的存储一定是连续的,链式存储结构的存储空间不一定是连续的16B) 顺序存储结构只针对线性结构,链式存储结构只针对非线性结构C) 顺序存储结构能存储有序表,链式存储结构不能存储有序表D) 链式存储结构比顺序存储结构节省存储空间参考答案:A【解析】顺序存储方式是把逻辑上相邻的结点存储在物理上相邻的存储单元里,结点之间的关系由存储单元的邻接关系来体现。其优点是占用最少的存储空间,所以选项D)错误。顺序存储结构可以存储如二叉树这样的非线性结构,所以选项B)错误。链式存储结构也可以存储线性表,所以选项C)错误。5.数据流图中带有箭头的线段表示的是_。A) 控制流 B) 事件驱动C) 模块调用
18、 D) 数据流参考答案:D【解析】在数据流图中,矩形表示数据的外部实体,圆角的矩形表示变换数据的处理逻辑,双横线表示数据的存储,箭头表示数据流。6.在软件开发中,需求分析阶段可以使用的工具是_。A) NS图 B) DFD图C) PAD图 D) 程序流程图参考答案:B【解析】数据流图简称DFD图,采用图形方式来表达系统的逻辑功能、数据在系统内部的逻辑流向和逻辑变换过程,是结构化系统分析方法的主要表达工具及用于表示软件模型的一种图示方法。所以DFD图可以用于需求分析阶段。7.在面向对象方法中,不属于“对象“基本特点的是_。A) 一致性 B) 分类性C) 多态性 D) 标识唯一性参考答案:A【解析】
19、对象是面向对象方法中最基本的概念,它的基本特点有:标识唯一性、分类性、多态性、封装性和模块独立性。故本题答案为A)。8.一间宿舍可住多个学生,则实体宿舍和学生之间的联系是_。A) 一对一 B) 一对多C) 多对一 D) 多对多参考答案:B【解析】一个实体宿舍可以对应多个学生,而一个学生只能对应一个宿舍,所以宿舍和学生之间是一对多关系。9.在数据管理技术发展的三个阶段中,数据共享最好的是_。A) 人工管理阶段 B) 文件系统阶段C) 数据库系统阶段 D) 三个阶段相同参考答案:C【解析】人工管理阶段:计算机出现的初期,主要用于科学计算,没有大容量的存储设备。处理方式只能是批处理, 数据不共享,不
20、同程序不能交换数据。文件系统阶段:把有关的数据组织成一种文件,这种数据文件可以脱离程序而独立存在,由一个专门的文件管理系统实施统一管理。但是,数据文件仍高度依赖于其对应的程序,不能被多个程序通用。数据库系统阶段:对所有的数据实行统一规划管理,形成一个数据中心,构成一个数据仓库,数据库中的数据能够满足所有用户的不同要求,供不同用户共享。数据共享性显著增强。故本题答案为C)。1710.有三个关系R、S和T如下:RA Bm 1n 2SB C1 33 5TA B Cm 1 3由关系R和S通过运算得到关系T,则所使用的运算为_。A) 笛卡尔积 B) 交C) 并 D) 自然连接参考答案:D【解析】自然连接
21、是一种特殊的等值连接。当关系R和S有相同的属性组,且该属性组的值相等时的连接称为自然连接。 11.以下叙述中正确的是_。A)C程序的基本组成单位是语句B)C程序中的每一行只能写一条语句C)简单C语句必须以分号结束D)C语句必须在一行内写完参考答案:C【解析】函数是 C 程序的基本组成单位;C 语言书写风格很自由,不但一行可以写多个语句,还可以将一个语句写在多行中。故本题答案为 C)。12.计算机能直接执行的程序是_。A)源程序 B)目标程序C)汇编程序 D)可执行程序参考答案:D【解析】计算机能直接执行的只能是机器语言程序,源程序和汇编程序都是用高级语言编写的程序,不能被直接执行。目标程序也是
22、不能被直接执行的程序,需要通过系统提供的连接程序与库函数连接装配成可执行程序,才能被计算机执行。所以本题答案为 D)。13.以下选项中不能作为C语言合法常量的是_。A)cd B)0.1e6C)“a“ D)011参考答案:A【解析】选项B)是实型常量,选项C)是字符串常量,选项D)是转义字符常量,都是合法的常量。14.以下选项中正确的定义语句是_。A)double a;b; B)double ab7;C)double a7,b7; D)double,a,b;18参考答案:C【解析】定义变量a和变量b为double类型,并对其赋初值。变量之间应以“,“ 分隔,定义关键字与变量名之间应以空格分隔,语
23、句应以“;“结尾。15.以下不能正确表示代数式2abcd的C语言表达式是_。A)2*a*b/c/dB)a*b/c/d*2C)a/c/d*b*2 D)2*a*b/c*d参考答案:D【解析】C语言中算术运算符的结合性均为自左向右。选项D)中表达式计算结果是2*a*b*d/c,和题目要求的代数式不一致,因此选项D)不能正确表示题目所给的代数式不一致,因此选项D)不能正确表示题目所给的代数式内容。16.C源程序中不能表示的数制是_。A)二进制 B)八进制C)十进制 D)十六进制参考答案:A【解析】C语言中整型常量可用十进制、八进制和十六进制3种形式表示。17.若有表达式(w)?(x):(y),则其中与
24、w等价的表达式是_。A)w1 B)w0C)w!1 D)w!0参考答案:D【解析】条件运算符组成条件表达式的一般形式为:表达式1?表达式2:表达式3。其求值规则为:如果表达式1的值为真,则以表达式2 的值作为条件表达式的值,否则以表达式3的值作为条件表达式的值。本题中需要获得表达式w的逻辑值,即w是否为0,不为0则为真,为0则为假。因此正确答案为D)。18.执行以下程序段后,w的值为_。int wA,x14,y15;w(xy) while(i!0);printf(“n“);程序的运行结果是_。A)*7 B)*3*5C)*5D)*2*6参考答案:A【解析】整个程序中只有对i增加的语句而没有对i减少
25、的语句,所以2、3都不可能出现,选项B)和D)错误。而i5时第一个if语句的表达式为假,所以选项C)也错误。30.有以下程序:#include int fun(int a,int b) if(b=0) return a;else return(fun(-a,-b);main() printf(“%dn“,fun(4,2);程序的运行结果是_。22A)1 B)2 C)3 D)4参考答案:B【解析】该题目考查函数参数传递以及if条件语句。当变量b为0时,将a的值返回给主调函数,因此a进行两次自减1后,将其值返回并输出。31.有以下程序:#include #include int fun(int n
26、) int *p;p(int*)malloc(sizeof(int);*pn; return *p;main() int a;afun(10); printf(“%dn“,afun(10);程序的运行结果是_。A)0 B)10C)20 D)出错参考答案:C【解析】分配内存空间函数malloc的调用形式:(类型说明符*)malloc(size)。其功能是在内存的动态存储区中分配一块长度为“size“字节的连续区域,函数的返回值为该区域的首地址。“类型说明符“表示把该区域用于何种数据类型。32.有以下程序:#include void fun(int a,int b) int t;ta; ab; b
27、t;main() int c101,2,3,4,5,6,7,8,9,0,i;for(i0;istruct st int x,y;data21,10,2,20;main() struct st *pdata;printf(“%d,“,py); printf(“%dn,(p)x);程序的运行结果是_。A)10,1 B)20,1C)10,2 D)20,2参考答案:C【解析】数组名的值即为数组首地址,所以py可得第一个元素的y值,(p)x可得第二个元素的x值。34.有以下程序:#include void fun(int a,int n) int i,t;for(i0;i24#define N 4voi
28、d fun(int aN,int b) int i;for(i0;iint fun(int (*s)4,int n,int k) int m,i;ms0k;for(il;im)msik;return m;main() int a441,2,3,4),11,12,13,14,21,22,23,24,31,32,33,34;printf(“%dn“,fun(a,4,0);程序的运行结果是_。A)4 B)34C)31 D)32参考答案:C【解析】fun函数中使用for循环语句和if条件语句对m进行赋值,主函数的功能是将fun函数中的m返回主调函数并输出。37.有以下程序:#include main(
29、) struct STU char name9; char sex; double score2; ;struct STU a“Zhao“,m,85.0,90.0,b“Qian“,f,95.0,92.0;25ba;printf(“%s,%c,%2.0f,%2.0fn“,b.name,b.sex,b.score0,b.score1);程序的运行结果是_。A)Qian,f,95,92 B)Qian,m,85,90C)Zhao,f,95,92 D)Zhao,m,85,90参考答案:D【解析】该题目考查结构体数据类型,注意语句ba,因此输出b.name为zhao,b.sex为m,依此类推。38.假定已
30、建立以下链表结构,且指针p和q已指向如下图所示的结点:则以下选项中可将q所指结点从链表中删除并释放该结点的语句组是 。A)(*p)next=(*q)next; free(p);B)p=q-next; free(q);C)p=q; free(q);D)p-next=q-next; free(q);参考答案:D【解析】要将结点b从链表中删除,应先将a的指针域指向b结点的下一个结点,即pnextqnext,然后释放指针q的空间。39.有以下程序:#include main() char a4;printf(“%dn“,aamain() FILE *pf;char *s1“China“,*s2“Bei
31、jing“;26pffopen(“abc.dat“,“wb“);fwrite(s2,7,1,pf);rewind(pf); /*文件位置指针回到文件开头*/fwrite(s1,5,1,pf);fclose(pf);以上程序执行后abc.dat文件的内容是_。A)China B)ChinangC)ChinaBeijing D)BeijingChina参考答案:B【解析】该题目考查文件相关知识。“wb“用于打开或建立二进制文件并允许对其进行读和写操作。文件操作先写入了s2,然后将文件指针移动到文件夹,再写入s1,这样s1就会覆盖掉一部分s2的内容。1.对下列二叉树进行中序遍历的结果是_【1】_ 。
32、参考答案:DBXEAYFZC【解析】二叉树中序遍历的顺序为先遍历左子树,然后访问根结点,最后遍历右子树。2.按照软件测试的一般步骤,集成测试应在_【2】_ 测试之后进行。参考答案:单元【解析】软件测试过程按4个步骤进行,即:单元测试、集成测试、确认测试和系统测试。3.软件工程三要素包括方法、工具和过程,其中,_【3】_支持软件开发的各个环节的控制和管理。参考答案:过程【解析】 软件工程包括三个要素:方法、工具和过程。方法为软件开发提供了“如何做“的技术;工具支持软件的开发、管理和文档生成;过程支持软件开发的各个环节的控制与管理。4.数据库设计包括概念设计、_【4】_和物理设计。参考答案:逻辑设
33、计【解析】数据库的设计过程大致分为3个步骤:概念设计、逻辑设计和物理设计。5.在二维表中,元组的_【5】_不能再分成更小的数据项。参考答案:分量【解析】 一张二维表对应一个关系,代表一个实体集,表中的一行称为一个元组。一个元组又由许多个分量组成,每个元组分量是表框架中每个属性的投影值。6.设变量a和b已正确定义并赋初值。请写出与aab等价的赋值表达式 _【6】_。参考答案:a=-b27【解析】aab等价于aa(ab),等价于ab。7.若整型变量a和b中的值分别为7和9,要求按以下格式输出a和b的值:a7b9请完成输出语句:printf(“_【7】_“,a,b);。参考答案:a=%dnb=%dn
34、【解析】“%d“表示按十进制整型输出,“n“表示回车换行。8.以下程序的输出结果是_【8】_。#include main() int i,j,sum;for(i3;i1;i) sum0;for(j1;jmain() int j,a1,3,5,7,9,11,13,15,*pa5;for(j3;j;j) switch(j) case 1:case 2: printf(“%d“,*p); break;case 3: printf(“%d“,*(p);参考答案:9 9 11【解析】由switch语句的用法可知,case 3的语句执行了一次,case 2的语句执行了两次。10.以下程序的输出结果是_【1
35、0】_。#include #define N 5int fun(int *s,int a,int n) int j;*sa; jn;while(a!sj)j;return j;28main() int sN1; int k;for(k1;kint fun(int x) static int t0;return(tx);main() int s,i;for(i1;imain() int x44,n0,i,j;for(j0;jj;_【12】_)n;xij_【13】_;for(i0;ilong_【14】_; /* 函数说明语句 */main()29 long n;nfunc(); printf(“n
36、%ldn“,n);long func() long m;for( m0;getchar()!;_【15】_);return m;参考答案:func() m+ 【解析】 第一空为函数说明语句,其格式为:函数标志符#函数名。第二空中的m作为计数器,每读一个字符时加1。2009 年 3 月真题1.下列叙述中正确的是_。A)栈是“先进先出“的线性表B)队列是“先进后出“的线性表C)循环队列是非线性结构D)有序线性表既可以采用顺序存储结构,也可以采用链式存储结构参考答案:D【解析】栈是“先进后出“的线性表;队列是“先进先出“的线性表;循环队列是队列的一种顺序存储结构,因此是线性结构;有序线性表既可以采用
37、顺序存储结构,也可以采用链式存储结构。2.支持子程序调用的数据结构是_。A)栈 B)树C)队列 D)二叉树参考答案:A【解析】栈支持子程序调用。栈是一种只能在一端进行插入或删除的线性表,在主程序调用子函数时要首先保存主程序当前的状态,然后转去执行子程序,最终把子程序的执行结果返回到主程序中调用子程序的位置,继续向下执行,这种调用符合栈的特点,因此本题的答案为 A)。3.某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是_。A)10 B)8 C)6 D)4参考答案:C【解析】对于任何一棵二叉树T,如果其终端结点(叶子)数为n1,度为2的结点数为n2,则n1n21。所以该二叉树的叶子结点数等于
38、516。4.下列排序方法中,最坏情况下比较次数最少的是_。A)冒泡排序 B)简单选择排序C)直接插入排序 D)堆排序参考答案:D【解析】冒泡排序、简单选择排序和直接插入排序在最坏情况下比较次数都是“n(n1)/2“,堆排序在最坏情况下比较次数最少,是“ “。5.软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软30件的是_。A)编译程序 B)操作系统C)教务管理系统 D)汇编程序参考答案:C【解析】软件按功能可以分为:应用软件、系统软件、支撑软件(或工具软件)。应用软件是为解决某一特定领域的应用而开发的软件;系统软件是计算机管理自身资源,提高计算机使用效率并为计算机
39、用户提供各种服务的软件;支撑软件是介于系统软件和应用软件之间,协助用户开发软件的工具性软件。编译程序、操作系统和汇编程序都属于系统软件;教务管理系统属于应用软件。6.下面叙述中错误的是_。A)软件测试的目的是发现错误并改正错误B)对被调试的程序进行“错误定位“是程序调试的必要步骤C)程序调试通常也称为DebugD)软件测试应严格执行测试计划,排除测试的随意性参考答案:A【解析】软件测试的目的是暴露错误,评价程序的可靠性。软件调试的目的是发现错误的位置,并改正错误。软件测试和调试不是同一个概念。7.耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是_。A)提高耦合性降低内聚性有利于提
40、高模块的独立性B)降低耦合性提高内聚性有利于提高模块的独立性C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度参考答案:B【解析】耦合性是模块间互相连接的紧密程度的度量,内聚性是一个模块内部各个元素间彼此结合的紧密程度的度量。一般较优秀的软件设计,应尽量做到高内聚,低耦合,即减弱模块之间的耦合性和提高模块内的内聚性,这样有利于提高模块的独立性。8.数据库应用系统中的核心问题是_。A)数据库设计 B)数据库系统设计C)数据库维护 D)数据库管理员培训参考答案:A【解析】数据库应用系统中的一个核心问题就是设计一个能满足用户需求、性能良好的数据库,这就是数据库设计。9.有两个关系R,S如下:由关系R通过运算得到关系S,则所使用的运算为_。A)选择 B)投影 C)插入 D)连接