2.18Java专项测试复盘
Posted L19
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2.18Java专项测试复盘相关的知识,希望对你有一定的参考价值。
结构型模式中最体现扩展性的模式是()
A. 装饰模式
B. 合成模式
C. 桥接模式
D. 适配器解析:装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。
答案:A以下描述正确的是()
A. CallableStatement是PreparedStatement的父接口
B. PreparedStatement是CallableStatement的父接口
C. CallableStatement是Statement的父接口
D. PreparedStatement是Statement的父接口解析:继承关系如图:
答案:B在开发中使用泛型取代非泛型的数据类型(比如用ArrayList
取代ArrayList),程序的运行时性能会变得更好。()
A. 正确
B. 错误解析:在编译阶段,虚拟机就会把泛型的类型擦除,还原成没有泛型的代码,顶多编译速度稍微慢一些,执行速度是完全没有什么区别的.
答案:B对文件名为Test.java的java代码描述正确的是()
class Person { String name = "No name"; public Person(String nm) { name = nm; } } class Employee extends Person { String empID = "0000"; public Employee(String id) { empID = id; } } public class Test { public static void main(String args[]) { Employee e = new Employee("123"); System.out.println(e.empID); } }
A. 输出:0000
B. 输出:123
C. 编译报错
D. 输出:No name解析:父类没有无参的构造函数,所以子类需要在自己的构造函数中显式调用父类的构造函数,添加super("nm");否则报错。
答案:C关于ThreadLocal类 以下说法正确的是
A. ThreadLocal继承自Thread
B. ThreadLocal实现了Runnable接口
C. ThreadLocal重要作用在于多线程间的数据共享
D. ThreadLocal是采用哈希表的方式来为每个线程都提供一个变量的副本
E. ThreadLocal保证各个线程间数据安全,每个线程的数据不会被另外线程访问和破坏解析:ThreadLocal并没有继承自Thread,也没有实现Runnable接口。所以AB都不对。ThreadLocal类为每一个线程都维护了自己独有的变量拷贝。每个线程都拥有了自己独立的一个变量。所以ThreadLocal重要作用并不在于多线程间的数据共享,而是数据的独立,C选项错。
答案:DE以下JAVA程序的运行结果是什么( )
public static void main(String[] args) { Object o1 = true ? new Integer(1) : new Double(2.0); Object o2; if (true) { o2 = new Integer(1); } else { o2 = new Double(2.0); } System.out.print(o1); System.out.print(" "); System.out.print(o2); }
A. 1 1
B. 1.0 1.0
C. 1 1.0
D. 1.0 1解析:三元操作符如果遇到可以转换为数字的类型,会做自动类型提升。若两个操作数都是直接量数字,则返回值类型为范围较大者
答案:D下列关于Java并发的说法中正确的是()
A. CopyOnWriteArrayList适用于写多读少的并发场景
B. ReadWriteLock适用于读多写少的并发场景
C. ConcurrentHashMap的写操作不需要加锁,读操作需要加锁
D. 只要在定义int类型的成员变量i的时候加上volatile关键字,那么多线程并发执行i++这样的操作的时候就是线程安全的了解析:A,CopyOnWriteArrayList适用于写少读多的并发场景
B,ReadWriteLock即为读写锁,他要求写与写之间互斥,读与写之间互斥,读与读之间可以并发执行。在读多写少的情况下可以提高效率
C,ConcurrentHashMap是同步的HashMap,读写都加锁
D,volatile只保证多线程操作的可见性,不保证原子性
答案:B下列哪个说法是正确的()
A. ConcurrentHashMap使用synchronized关键字保证线程安全
B. HashMap实现了Collction接口
C. Array.asList方法返回java.util.ArrayList对象
D. SimpleDateFormat是线程不安全的解析:ConcurrentHashMap 使用segment来分段和管理锁,segment继承自ReentrantLock,因此ConcurrentHashMap使用ReentrantLock来保证线程安全。C中,应该是Arrays.asList(),其将一个数组转化为一个List对象,这个方法返回一个ArrayList类型的对象, 这个ArrayList类并非java.util.ArrayList类,而是Arrays类的内部类:java.util.Arrays.ArrayList
答案: DURL u =new URL("http://www.123.com");。如果www.123.com不存在,则返回______。
A. http://www.123.com
B. ””
C. null
D. 抛出异常解析:new URL()时必须捕获检查异常,但这个异常是由于字符串格式和URL不符导致的,这个异常属于IOException,与网址是否存在无关。URL的toString方法返回字符串,无论网址是否存在。
答案:A已知如下的命令执行 java MyTest a b c 请问哪个语句是正确的? ( )
A. args[0] = "MyTest a b c"
B. args[0] = "MyTest"
C. args[0] = "a"
D. args[1]= "b"解析:对于java命令,类名后面跟着的就是main函数的参数,多个参数则用空格隔开。 main方法的形参是一个string数组所以对于java mytest a b c传入的参数算是一个string数组。 即args[0]=a args[1]=b args[2]=c
答案:CDGiven the following code:
import EnclosingOne.InsideOne class Enclosingone { public class InsideOne {} } public class inertest { public static void main(string[]args) { EnclosingOne eo = new EnclosingOne(); //insert code here } }
A. InsideOne ei=eo.new InsideOne();
B. eo.InsideOne ei=eo.new InsideOne();
C. InsideOne ei=EnclosingOne.new InsideOne();
D. EnclosingOne.InsideOne ei=eo.new InsideOne();解析:因为import EnclosingOne.InsideOne,所以A正确。内部类其实和类的属性没什么区别,只是在声明的时候必须是Outer.Inner a,所以D正确。
答案:AD
以上是关于2.18Java专项测试复盘的主要内容,如果未能解决你的问题,请参考以下文章