计算机二级Java语言卷015
Posted M了个J
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了计算机二级Java语言卷015相关的知识,希望对你有一定的参考价值。
选择题
公共知识
【1】设有一个栈与一个队列的初始状态均为空。现有一个序列A, B, C, D, E, F, G, H, 先分别将序列中的前4个元素依次入栈, 后4个元素依次入队; 然后分别将栈中的元素依次退栈, 再将队列中的元素依次退队。最后得到的序列为()。
栈的特点是先进后出, 而队列是先进先出。前4个元素依次进栈为ABCD, 出栈后为DCBA, 后4个元素入队列为EFGH, 出队也是EFGH, 最后得到的序列为DCBAEFGH。故D项正确。
【2】设某棵树的度为3, 其中度为2, 1, 0的结点个数分别为3, 4, 15。则该树中总结点数为()。
在树结构中, 一个结点所拥有的后件个数称为该结点的度, 所有结点中最大的度称为树的度, 树中的结点数即为树中所有结点的度数之和再加1。假设度为3的结点数为n, 总结点数为m, m = 3×n + 2×3 + 1×4 + 1, 叶子结点数15 = m - (3 + 4 + n)。得m = 3n + 11, 2n = 11, n无法得到整数, 说明不可能存在这样的树。故答案为D。
【3】设二叉树的前序序列为ABDEGHCFIJ, 中序序列为DBGEHACIFJ。则按层次输出(从上到下, 同一层从左到右)的序列为()。
二叉树遍历可以分为3种: 前序遍历(访问根结点在访问左子树和访问右子树之前)、中序遍历(访问根结点在访问左子树和访问右子树两者之间)、后序遍历(访问根结点在访问左子树和访问右子树之后)。二叉树的前序遍历序列为ABDEGHCFIJ, 中序序列为DBGEHACIFJ, 可知该树A为根结点, 右子树结点为CFIJ, 左子树结点为BDEGH。从顶向下从左向右依次为ABCDEFGHIJ, A项正确。
【4】设顺序表的长度为16, 对该表进行简单插入排序。在最坏情况下需要的比较次数为()。
简单插入排序在最坏情况下, 即初始排序序列是逆序的情况下, 比较次数为n(n - 1) / 2, 移动次数为n(n - 1) / 2。本题中即16×(16 - 1)÷2 = 8×15 = 120。故答案为D。
【5】软件系统总体结构图的作用是()。
软件系统总体结构图是描述软件系统结构的图形工具, 它包括软件系统的控制流、软件系统的数据流、软件系统的数据结构等的概括。故答案为A。
【6】不属于对象构成成份的是()。
一个对象通常可由对象名、属性和操作三部分组成, 对象名唯一标识一个对象。故答案为B。
【7】十进制整数设为整数类I, 则下面属于类I的实例的是()。
类是具有共同属性、共同方法的对象的集合。-518是整数, 0.518是浮点数, 518E - 2是指数。故答案为A。
【8】结构化程序设计原则强调的是()。
结构化程序设计的原则强调自顶向下、逐步求精、模块化、限制使用goto语句。故答案为A。
【9】违背数据流图(DFD)构造规则的是()。
数据流图应遵循以下构造规则和注意事项:
①对加工处理建立唯一、层次性的编号, 且每个加工处理通常要求既有输入又有输出。
②数据存储之间不应有数据流。
③数据流图的一致性。即输入输出、读写的对应。
④父图、子图关系与平衡规则。相邻两层DFD之间具有父子关系, 子图代表了父图中某个加式的详细描述, 父图表示了子图间的接口。子图个数不大于父图中的处理个数。所有子图的输入输出数据流和父图中相应处理的输入输出数据流必须一致。故答案为B。
【10】规范化主要为克服数据库逻辑结构中的插入异常, 删除异常以及()。
关系数据库进行规范化的目的是使结构更合理, 消除存储异常, 使数据冗余尽量小, 便于插入、删除和更新。关系模式进行规范化的原则: 遵从概念单一化“一事一地”原则, 即一个关系模式描述一个实体或实体间的一种联系。规范的实质就是概念的单一化。 故答案为D。
专业知识
【11】下列对Java语言的描述中, 正确的是
选项B: 构造方法没有返回值, 且不能写void, 错误; 选项C: 构造方法可以进行重载, 有参构造函数和无参构造函数就是重载, 错误; 选项D: 垃圾回收机制是系统级的线程, 错误; 选项A正确, 本题答案为A。
【12】下列选项中, 属于Java文档注释的是
选项A没有这种注释, 错误; 选项B属于单行注释, 错误; 选项C属于多行注释, 错误; 选项D正确, 本题答案为D。
【13】下列选项中, 不符合Java标识符规定的是
java命名规则: 1可以由字母, 数字, ”_”或者”$”符组成, 但是不能以数字开头; 2.中文可以作为变量名, 但是不提倡使用; 3.Java大小写敏感, 严格区分大小写, 命名时需要注意; 4.不能使用Java保留字; 选项A不符合命名规则, 本题答案为A。
【14】下列代码段执行后, t的值为
int a = 6, b = 9, c = 3, t = 0 ;
t = a > b ? (a > c ? a : c): (b > c ? b : c);
本题考查条件运算符的应用, 关系表达式 ? 表达式1 : 表达式2; 关系表达式返回true, 结果为表达式1的值, 否则为表达式2的值。将程序中的带入可知结果为9, 选项D正确, 本题答案为D。
【15】使表达式 x > 0 && x <= 10 || x > 100的值为false的选项是
值为false首先需要满足x < 100, 其次x < 0或者x > 10, 选项C正确, 本题答案为C。
【16】下列选项中, 不能正确表示无限循环的是
while循环中的条件应为布尔表达式, 选项B无法判断对错, 写法错误, 本题答案为B。
【17】switch语句的格式为 switch (表达式) { }, 其表达式的类型不允许是
switch语句在数据类型上受到限制, 只能使用int、byte、short、char类型。如果比较的数据类型是float型或者boolean类型, 就只能使用if - else if结构。本题答案为C
【18】下列代码段执行后, s的值为
int s = 0;
for (int i = 1; i <= 8; i++) {
if (i % 2 == 0) continue;
s = s + i;
}
本题考查continue, 当满足条件时, 跳出本次循环 , 执行下次循环。所以计算的过程是1 + 3 + 5 + 7 = 16, 选项B正确。本题答案为B。
【19】下列代码段执行后, n的值为
int n = 0;
for (int i = 1; i <= 3; i++) {
n = 0;
for (int j = 1; j <= 2 * i - 1; j++)
n++;
}
因为大循环中每次循环n都被初始化为0, 所以只需看最后一次执行i = 3结果。执行结果为5, 选项B正确, 本题答案为B。
【20】下列代码段执行后的结果是
int[] a = { 1, 2, 3, 4, 5 };
for (int i = 0 ; i < 5 ; i++)
a[i] = a[(i + 1) % 5 ];
for (int i = 0 ; i < 5 ; i++)
System.out.print(a[i] + " ");
i = 0时, (i + 1) % 5 = 1, a[0] = 2;
i = 1时, (i + 1) % 5 = 2, a[1] = 3;
…
i = 4时, (i + 1) % 5 = 0, a[0] = 2; 此时a[0]已经被改变为2
本题答案为B。
【21】Java中, 定义子类继承父类用到的关键字是
B: this关键字主要有三个应用: (1) this调用本类中的属性, 也就是类中的成员变量; (2) this调用本类中的其他方法; (3) this调用本类中的其他构造方法, 调用时要放在构造方法的首行
C: 英文单词继承意思, 和Java无关
D: 可以声明成员变量、方法、类以及本地变量。一旦你将引用声明作final, 你将不能改变这个引用了, 编译器会检查代码, 如果你试图将变量再次初始化的话, 编译器会报编译错误。
选项A正确, 本题答案为A。
【22】定义接口的关键字是
选项ABD主要用来修饰成员变量和类, 定义接口用关键字interface, 选项C正确, 本题答案为C。
【23】下列语句执行后, i的值为
String str = "rock-n-roll";
String str1 = "ro";
int i = str.indexOf(str1);
Java中字符串中子串的查找共有四种方法, 如下: 1、int indexOf(String str): 返回第一次出现的指定子字符串在此字符串中的索引。
2、int indexOf(String str, int startIndex): 从指定的索引处开始, 返回第一次出现的指定子字符串在此字符串中的索引。
3、int lastIndexOf(String str): 返回在此字符串中最右边出现的指定子字符串的索引。
4、int lastIndexOf(String str, int startIndex): 从指定的索引处开始向后搜索, 返回在此字符串中最后一次出现的指定子字符串的索引。
由此可知选项A正确, 本题答案为A。
【24】如果要判断两个字符串a 和b是否相等(不区分大小写)应该选用的方法是
选项A: equals比较区分大小写选项B: 赋值语句 选项C: 用于数值比较, 选项D比较字符串不区分大小写, 符合题目要求, 本题答案为D。
【25】下列程序段的运行结果是
int[][] a = new int[4][4];
int i, j, s = 0;
for (i = 0; i < 4; i++)
for (j = 0; j < 4; j++)
a[i][j] = i * j;
for (i = 0; i < 4; i++)
s = s + a[i][i];
System.out.print(s);
本题考查二维数组的运算, 双层for循环中的执行结果为4行4列的矩阵, 带入相关值, 可知a[0][0]为0, a[1][1]为1, a[2][2]为4, a[3][3]位9, 可知最终结果为14, 选项B正确, 本题答案为B。
【26】整数算术运算中, 当除数为0时产生的异常是
A: 数组下标越界, B: 被除数为0 , C: 空指针异常 , 本题答案为D。
【27】执行下列程序段时, 若文件"file.dat"不存在, 则输出结果是
try {
FileInputStream fis = new FileInputStream("file.dat");
} catch (FileNotFoundException e) {
System.out.print("FileNotFoundException")
} catch (IOException e) {
System.out.print("IOException")
}
在处理异常时遵循: 先逮小的(先处理小范围中的异常), 再逮大的(小范围没有处理异常的操作, 往其父类中查找解决异常), 本程序中文件找不到, 有FileNotFoundException这个处理异常, 则后面的异常不会被执行, 选项A正确, 本题答案为A。
【28】Map接口中, 插入 < 关键字, 值 > 条目的方法是
选项A: 通过key, 取得value值 , 错误, 选项CD Map中无此方法, 选项B正确, 本题答案为B。
【29】压缩流所在的包是
选项A: 实现zip压缩和解压, 选项 B: 音频播放, 选项C: 简单的图像操作, 选项D: 解压xml文件, 本题答案为A
【30】将一个字节数组作为输出流写入内存的类是
A: 允许应用程序创建, 其中读取的字节由字符串的内容提供的输入流B: 管道流可以实现两个线程之间, 二进制数据的传输D: 数据模型序列化
本题答案为C。
【31】创建文件目录时, 所使用的方法是
本题考查文件类提供的方法。mkdir0是为目录操作提供的方法, 用来创建目录; mkdirs()也是为目录操作提供的方法, 创建包含父目录的目录; list()是对文件名操作提供的方法, 返回一个字符串数组, 为该文件所在目录下的所有文件名列表, isFile()判断一个文件是否属于标准的目录。本题答案为C。
【32】下列代码实现了将一个文件的内容复制到另一个文件的功能。下划线处应填入的代码是
import java.io.*;
public class test {
public static void main(String[] args) {
try {
FileInputStream is = new FileInputStream("D:from.txt");
FileOutputStream os = new _______________("D: o.txt");
byte[] str = new ___________[1024];
while (is.available() > 0) {
is.read(str, 0, 1024);
os.write(str);
}
is.close();
os.close();
} catch (ArrayIndexOutOfBoundsException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
文件输出流, 是用于将数据写入File或 FileDescriptor的输出流 , 使用给定的 charset 将此 String 编码到 byte 序列, 并将结果存储到新的 byte 数组 选项A正确, 本题答案为A。
【33】文本字段或文本区域发生改变时所产生的事件是
A: 鼠标点击事件, B: 窗口事件, C: 当页面中的元素获得或失去焦点时触发, 选项D正确, 本题答案为D。
【34】Swing组件的事件类所在的包是
Swing组件的事件类所在的包是javax.swing.event
【35】
A错误提示框 B: 基本提示框C: 警告D: 选择 本题答案为B。
【36】下列选项中, 不是Java线程组成部分的是
线程是程序中的一个执行流。一个执行流是由CPU运行程序的代码、操纵程序的数据所形成的。Java中的线程模型包含3部分: 一个虚拟的CPU, 该CPU执行的代码, 代码所操作的数据。选项C不属于组成部分, 本题答案为C。
【37】为了使下列程序正常运行并且输出"(1,1) (2,2) (3,3) ", 在下划线处应填入的是
public class Test2 ___________ {
private int x = 0;
private int y = 0;
boolean flag = true;
public static void main(String[] args) {
Thread t1 = new ________ ;
t1.start();
}
public void run() {
while (flag) {
x++;
y++;
System.out.print("(" + x + "," + y + ") ");
if (x >= 3)
flag = false;
}
}
}
Thread类是多线程基类, 多线程启动类必须继承此类。而实现Runnable接口的类能作为多线程的一个执行任务, 一般作为参数传给新的Thread类。选项C正确, 本题答案为C。
【38】在一个线程的生命周期中, 不能多次被调用的方法是
启动线程start()只能调用一次, 选项B正确, 本题答案为B。
【39】下列选项中, 属于Applet生命周期方法的是
init: 该方法用于初始化Applet, 当applet首先被加载时, 该方法会自动被调用一次。
start: 该方法在Java调用init方法之后被调用, 当用户从其他页面返回到包含Applet的页面中时, 该方法也会被调用, 它与init方法不同。有鉴于此, 应该把调用一次的代码放到init方法中, 而非start方法中。start方法通常是为Applet重起一个线程的地方, 如果当用户回到当前网页的时候不需要做任何操作, 那么就不需要实现此方法。
stop: 该方法在用户离开Applet页面时, 被自动调用。因此, 其也能被多次重复调用。主要作用是当用户不再关注Applet时能够停止一些没用的动作。典型作用是挂起一个线程。
destroy: 当浏览器被正常关闭时, JVM会自动调用此方法。该方法中放置的代码主要是用来回收一些系统资源
本题答案为A。
/*test.html*/
<HTML>
<HEAD>
<TITLE > Applet Test </TITLE>
</HEAD>
<BODY>
< _______ CODE = "AppletTest3.class"WIDTH = 150 HEIGHT = 25>
</ _______ >
</BODY>
</HTML>
/* AppletTest3.java*/
import java.awt.*;
import __________ ;
public class AppletTest3 extends JApplet {
JButton b;
public void init() {
Container contentPane = getContentPane();
b = new JButton("Try!");
contentPane.add(b);
}
}
JApplet类属于Applet的扩展类, java中扩展类都存放在javax包中, JApplet属于swing窗口中的构件, 选项B, C错误, 在浏览器中通过 < APPLET> 获取java中的参数, 选项D正确, B错误, 本题答案为D。
以上是关于计算机二级Java语言卷015的主要内容,如果未能解决你的问题,请参考以下文章