Java解惑八:很多其它库之谜

本文是依据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. 主线程也在等待后台线程结束。造成死锁。

转载于:https://www.cnblogs.com/gcczhongduan/p/5094130.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值