安卓巴士自测试题-第三期

1. 下面代码视图实现单例模式,可是犯了2处明显的错误,请找出这2个错误。 java

public class Singleton {
    public Singleton() {
           System.out.println("Singleton is create");
    }

    private Singleton instance = new Singleton();
 
    public static Singleton getInstance() {
           return instance;
    }

   public static void createString(){                       
           System.out.println("createString in Singleton");
   }
}

2. 对代理模式的做用,描述最不恰当的一项是(单选题)
A.控制对象访问和通讯 
B.延迟加载,提高系统性能 
C.
处于安全目的,保护被访问者
D.动态扩充对象功能

3.Android UI体系中,事件通知实现的基本思想来源于(单选题):
A.观察者模式
B.代理模式
C.策略模式
D.装饰者模式

4. VectorArrayList的主要区别是(单选题):
A. ArrayList内部基于链表,而Vector是基于数组的
B. Vector的大部分方法作了同步,而ArrayList没有同步
C. Vector是可串行化的,而ArrayList不是
D. Vector实现了RandomAccess,而ArrayList没有

5. 若是HashMap发生大量Hash冲突,则会致使(单选题):
A. HashMap崩溃,致使不可用
B. HashMap没有影响,依然能够高效的工做
C. HashMap的性能会有一点影响,但整体依然是高效的
D. HashMap依然可用,可是性能受到重创。

6. 下面哪些关键字是和多线程并发有关的(多选)
A. volatile
B. synchronized
C. public
D. final

7. ReadWriteLock可以提升并发性能的缘由是(单选):
A. 它是无锁的操做
B. 它为每一个线程都提供了一份数据的复本
C. 它可使得读读操做真正的并发,无需等待
D. 它自动进行了锁的粗化

8. 对象池和享元模式的根本不一样在于(单选):
A. 对象池中的对象能够复用,享元模式中的对象不能复用
B. 对象池能够提高系统性能,享元模式不能
C. 对象池中的每一个对象都是等价的,享元模式中的每一个对象是不等价的
D. 对象池中的每一个对象是不等价的,享元模式中的每一个对象是等价的

9.下面哪些是String对象的特性(多选)
A. 不变性
B. 针对常量池的优化
C. 类是final
D. 用户可自定义的多态

10.简要分析StringsubString()方法形成内存泄漏的缘由 数组

答案: 安全

1.第2行 public改成private;6行 加上static。能够参考《Java程序性能优化》 第2章节-单例模式
2.D (解释:这个是装饰者模式的功能)
3.A (与Swing同样,事件通知,数据变化时使用的广泛方法是利用观察者模式)        有关装饰者模式 能够参考《Java程序性能优化》 第2章节-装饰者模式
4.B
5.D (分析:大量冲突时HashMap退化为链表,性能收严重影响)有关HashMap的工做原理能够参考《Java程序性能优化》 第3章节-Map接口。
6.A B
7.C有关对象池和享元模式 能够参考《Java程序性能优化》 第2章节-享元模式和第2章节-对象复用
8.C有关对象池和享元模式 能够参考《Java程序性能优化》 第2章节-享元模式和第2章节-对象复用
9.A,B,C有关String的介绍,能够参考《Java程序性能优化》 第3章节-字符串优化处理
10.简答:
substring()方法的实现中使用如下形式构造新的字符串:
new String(offset + beginIndex, endIndex - beginIndex, value);
该构造方法实现以下:
String(int offset, int count, char value[]) {
        this.value = value;
        this.offset = offset;
        this.count = count;
    }
可见,并无对value进行裁剪,只是设置了偏移量。所以使用subString()会形成泄漏。
相关文章
相关标签/搜索