Java|资深架构师整理分享60道全套Java核心技术面试题及答案( 四 )


java.lang.String 类是 final 类型的 , 因此不可以继承这个类、不能修改这个类 。 为了提高效率节省空间 , 我们应该用 StringBuffer 类
37、int 和 Integer 有什么区别
答:Java 提供两种不同的类型:引用类型和原始类型(或内置类型) 。 Int 是 java 的原始数据类型 , Integer 是 java 为 int 提供的封装类 。 Java 为每个原始类型提供了封装类 。
原始类型封装类booleanBooleancharCharacterbyteByteshortShortintIntegerlongLongfloatFloatdoubleDouble引用类型和原始类型的行为完全不同 , 并且它们具有不同的语义 。 引用类型和原始类型具有不同的特征和用法 , 它们包括:大小和速度问题 , 这种类型以哪种类型的数据结构存储 , 当引用类型和原始类型用作某个类的实例数据时所指定的缺省值 。 对象引用实例变量的缺省值为 null , 而原始类型实例变量的缺省值与它们的类型有关
38、运行时异常与一般异常有何异同
答:异常表示程序运行过程中可能出现的非正常状态 , 运行时异常表示虚拟机的通常操作中可能遇到的异常 , 是一种常见运行错误 。 java 编译器要求方法必须声明抛出可能发生的非运行时异常 , 但是并不要求必须声明抛出未被捕获的运行时异常 。
39、说出 ArrayListVector LinkedList 的存储性能和特性
答:ArrayList 和 Vector 都是使用数组方式存储数据 , 此数组元素数大于实际存储的数据以便增加和插入元素 , 它们都允许直接按序号索引元素 , 但是插入元素要涉及数组元素移动等内存操作 , 所以索引数据快而插入数据慢 , Vector 由于使用了 synchronized 方法(线程安全) , 通常性能上较 ArrayList 差 , 而 LinkedList 使用双向链表实现存储 , 按序号索引数据需要进行前向或后向遍历 , 但是插入数据时只需要记录本项的前后项即可 , 所以插入速度较快 。
40、HashMap 和 Hashtable 的区别
答:HashMap 是 Hashtable 的轻量级实现(非线程安全的实现) , 他们都完成了 Map 接口 , 主要区别在于 HashMap 允许空(null)键值(key)由于非线程安全 , 效率上可能高于 Hashtable 。
HashMap 允许将 null 作为一个 entry 的 key 或者 value , 而 Hashtable 不允许 。
HashMap 把 Hashtable 的 contains 方法去掉了 , 改成 containsvalue 和 containsKey 。 因为 contains 方法容易让人引起误解 。
Hashtable 继承自 Dictionary 类 , 而 HashMap 是 Java1.2 引进的 Map interface 的一个实现 。
最大的不同是 , Hashtable 的方法是 Synchronize 的 , 而 HashMap 不是 , 在多个线程访问 Hashtable 时 , 不需要自己为它的方法实现同步 , 而 HashMap 就必须为之提供外同步 。
Hashtable 和 HashMap 采用的 hash/rehash 算法都大概一样 , 所以性能不会有很大的差异 。
41、heap 和 stack 有什么区别
答:栈是一种线形集合 , 其添加和删除元素的操作应在同一段完成 。 栈按照后进先出的方式进行处理 。 堆是栈的一个组成元素
42、Java 的接口和 C++的虚类的相同和不同处答:由于 Java 不支持多继承 , 而有可能某个类或对象要使用分别在几个类或对象里面的方法或属性 , 现有的单继承机制就不能满足要求 。 与继承相比 , 接口有更高的灵活性 , 因为接口中没有任何实现代码 。 当一个类实现了接口以后 , 该类要实现接口里面所有的方法和属性 , 并且接口里面的属性在默认状态下面都是 public static所有方法默认情况下是 public.一个类可以实现多个接口 。
43、Java 中的异常处理机制的简单原理和应用
答:当 JAVA 程序违反了 JAVA 的语义规则时 , JAVA 虚拟机就会将发生的错误表示为一个异常 。
违反语义规则包括 2 种情况 。 一种是 JAVA 类库内置的语义检查 。 例如数组下标越界会引发 IndexOutOfBoundsException;访问 null 的对象时会引发 NullPointerException 。 另一种情况就是 JAVA 允许程序员扩展这种语义检查 , 程序员可以创建自己的异常 , 并自由选择在何时用 throw 关键字引发异常 。 所有的异常都是 java.lang.Thowable 的子类 。
43、垃圾回收的优点和原理 。 并考虑 2 种回收机制
答:Java 语言中一个显著的特点就是引入了垃圾回收机制 , 使 c++程序员最头疼的内存管理的问题迎刃而解 , 它使得 Java 程序员在编写程序的时候不再需要考虑内存管理 。 由于有个垃圾回收机制 , Java 中的对象不再有\"作用域\"的概念 , 只有对象的引用才有\"作用域\" 。 垃圾回收可以有效的防止内存泄露 , 有效的使用可以使用的内存 。 垃圾回收器通常是作为一个单独的低级别的线程运行 , 不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收 , 程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收 。 回收机制有分代复制垃圾回收和标记垃圾回收 , 增量垃圾回收 。