书里有些内容已过时,有些内容有点凑数,但还是有一点点收获,个人总结如下:
- 奇偶判断
书里:i % 2 == 0 ? "偶数" : "奇数"
,因为负奇数%2的结果是 -1,所以不能用i % 2 == 1
来判断奇偶。
推荐:i & 1 == 0 ? "偶数" : "奇数"
,除了效率高,还适用于i & 1 == 1
的判断方式。
System.out.println(-5 & 1); 1
System.out.println(-5 % 2); -1
安利另外几个公式:
a ^ b ^ b = a,一个数异或同一个数2次,值不变。
a * 2b = a << b, 左移b位
a / 2b = a >> b, 右移b位
a % 2b = a & (2b - 1),HashMap源码中hash值 % 数组length
就使用了该公式。
System.out.println(8 * 4 == 8 << 2); true
System.out.println(8 / 4 == 8 >> 2); true
构造代码块的原理
为什么构造代码块先于构造函数执行?Java字符串
Java字符串的“==”和“+”Java集合
Java中List和Map操作效率注意事项Java泛型
Java泛型的机制是只存在于编译期,运行时擦除。
e.g.new LinkedList<String>()
经过编译后new LinkedList()
。
另外关于泛型书写技巧,建议多看看JDK的源码。还有必要了解一下泛型方法的书写方式(曾经面试时被人要求手写过):
public class Test<T> {
public static <T> T get1(T t) {
return t;
}
public T get2(T t) {
return t;
}
}
Java异常体系
Java异常体系详解 待填坑Java日期类
SimpleDateFormat的线程安全问题 待填坑
Java8新增日期类工厂模式:
使用枚举实现工厂模式:
public enum EnumFactory {
Dog, Cat;
public Animal create() {
switch (this) {
case Cat:
return new Cat();
case Dog:
return new Dog();
default:
return null;
}
}
}
原始工厂模式:
public class BeanFactory {
public static Animal getBean(Class<? extends Animal> c) {
try {
return c.newInstance();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
return null;
}
}
相比较,我并不认为书中所说枚举工厂更好。
当新增子类的时候,原始工厂模式的工厂类不需要修改,而枚举工厂类却需要修改。当子类很多的时候,switch
语句会很长。作者又凑数了?