1. JDK基础知识结构
JDK1.8中一级java包有14个,我们需要掌握的有
java.util 包含集合框架、集合类、日期和时间设施、以及其他程序类。
java.io 通过数据流、序列化和文件系统提供系统输入输出
java.nio 定义缓冲区,它们是数据容器,并提供NIO包的概述
java.lang 编程基础类
2. 经典面试题
-
2.1. 你常用的JDK类有哪些?请说出5个。
String、StringBuffer、Integer、ArrayList、HashMap、Date、Object(选择熟悉的5个)
-
2.2 "String、StringBuilder、StringBuffer的区别是什么?"
1、可变性: String不可变,StringBuilder与StringBuffer是可变的。 String类中使用只读字符数组保存字符串,private final char value[], 所以是不可变的(Java 9 中底层把 char 数组换成了 byte 数组,占用更少的空间)。 StringBuilder与StringBuffer都继承自AbstractStringBuilder类,在AbstractStringBuilder中也是使用字符数组保存字符串, char[]value,这两种对象都是可变的。 2、线程安全性: String和StrinbBuffer是线程安全的,StringBuilder是非线程安全的。 String线程安全是因为其对象是不可变的,StringBuffer线程安全是因为对方法加了同步锁或者对调用的方法加了同步锁。 StringBuilder并没有对方法进行加同步锁,所以是非线程安全的。 3、性能: String的性能较差,因为每次对String 类型进行改变的时候,都会生成一个新的String对象,然后将指针指向新的String 对象。 而StringBuffer/StringBuilder性能更高,是因为每次都是对对象本身进行操作, 而不是生成新的对象并改变对象引用。一般情况下StringBuilder 相比StringBuffer 可获得10%~15% 左右的性能提升。
总结:
如果要操作少量的数据用 String;
单线程操作字符串缓冲区下操作大量数据 StringBuilder;
多线程操作字符串缓冲区下操作大量数据 StringBuffer;
-
2.3 int和Integer的区别?
int是java内置的8种基本数据类型之一,而Integer是Java为int引入的对应的包装类型(wrapper class)。 从Java 5开始引入了自动装箱/拆箱机制,使得二者可以相互转换。 public static void main(String[] args) { Integer a = new Integer(3); Integer d = new Integer(3); // 通过new来创建的两个Integer对象 Integer b = 3; // 将3自动装箱成Integer类型int c = 3; int c = 3; // 基本数据类型3 System.out.println(a == b); // false 两个引用没有引用同一对象 System.out.println(a == d); // false 两个通过new创建的Integer对象也不是同一个引用 System.out.println(c == b); // true b自动拆箱成int类型再和c比较
当两边都是Integer对象时,是引用比较;当其中一个是int基本数据类型时,另一个Integer对象也会自动拆箱变成int类型再进行值比较。
public static void main(String[] args) {
Integer f1 = 100;
Integer f2 = 100;
Integer f3 = 150;
Integer f4 = 150;
System.out.println(f1 == f2); // true,当int在[-128,127]内时,结果会缓存起来
System.out.println(f3 == f4); // false,属于两个对象
}
简单的说,如果整型字面量的值在-128到127之间,那么不会new新的Integer对象,而是直接引用常量池中的Integer对象,所以上面的面试题中f1f2的结果是true,而f3f4的结果是false。
-
2.4 两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这样说对不对?
不对。如果两个对象x和y满足x.equals(y) == true,它们的hash code应当相同。 Java对于eqauls方法和hashCode方法是这样规定的:(1)如果两个对象相同(equals方法返回true), 那么它们的hashCode值一定要相同;(2)如果两个对象的hashCode相同,它们并不一定相同。
-
2.5 如果你的Serializable类中包含一个不可序列化的成员,会发生什么?如何解决呢?
任何序列化该类的尝试都会因NotSerializableException而失败, 但这可以通过在 Java中给属性设置瞬态(transient)变量来轻松解决。
-
2.6 String类型为什么设计成final且不可变的?
1.不可变性支持线程安全。 String类被final修饰,是不可继承和修改的。 当一个String变量被第二次赋值时, 不是在原有内存地址上修改数据,而是在内存中重新开辟一块内存地址,并指向新地址。 2.不可变性支持字符串常量池,提升性能。 3.String字符串作为最常用数据类型之一,不可变防止了随意修改,保证了数据的安全性。