本文是依据JAVA解惑这本书,做的笔记。
电子书见:http://download.csdn.net/detail/u010378705/7527721
谜题76
将线程的启动方法start(),写成了run();PS:管程(monitor)锁有待进一步理解。谜题77
线程中锁的问题。理解不深刻。谜题78
反射会造成訪问其它包中的非公共类型的成员。引起执行期异常。谜题79
遮蔽:Thread.sleep()方法遮蔽了自定的方法。谜题80
反射:怎样实例化非静态内部类以及静态内部类。谜题81
System.out.write():不会自己主动刷新。须要使用System.out.flush()来刷新。谜题82
Process使用的问题,没看懂。谜题83
单例模式与序列化之间的关系。public class Dog extends Exception { private static final long serialVersionUID = 1L; public static final Dog INSTANCE = new Dog(); private Dog() {} public String toString() { return "Woof"; } private Object readResolve() { return INSTANCE; } }Exception实现了Serializable,必须有一个readResolve方法,用以返回它的唯一的实例。否则能够用反序列化,获取多个对象。谜题84
Thread.interrupted()方法。清除当前线程的中断状态。Thread.isInterrupted()方法,仅仅是查询中断状态。谜题85
在类的初始化期间等待某个后台线程非常可能会造成死锁。public class Lazy { private static boolean initialized = false; static { Thread t = new Thread(new Runnable() { public void run() { initialized = true; } }); t.start(); try { t.join(); } catch (InterruptedException e) { e.printStackTrace(); } } public static void main(String[] args) { System.out.println(initialized); } }
1. 主线程调用Lazy.main方法时,检查Lazy类是否已经被初始化,此时没有,所以主线程会记录下当前正在进行初始化。并对这个类进行初始化。2. 主线程将initialized的值设为false,创建后台线程。该改后台线程将initialized设为true,此时主线程会等待后台线程运行完成。3. 可是当后台线程调用run方法。将Lazy.initialized设为true之前,也会检查Lazy类是否已经被初始化。这个类正在被主线程进行初始化。后台线程会等待,直到初始化完毕。
4. 主线程也在等待后台线程结束。造成死锁。