谜题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. 主线程也在等待后台线程结束。造成死锁。
Java解惑八:更多库之谜,布布扣,bubuko.com
Java解惑八:更多库之谜