多线程共享堆空间,栈空间独立,多进程独享堆空间和栈空间。
锁池和等待池如图所示:
假设一个线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁,同时线程A就进入到了该对象的等待池中。如果另外的一个线程调用了相同对象的notifyAll()方法,那么处于该对象的等待池中的线程就会全部进入该对象的锁池中,准备争夺锁的拥有权。哪个线程最终能争取到锁由操作系统决定。
解决死锁的方案,避免死锁:要保持顺序锁,不要回调,反向打开
if和while的问题
使用while会多检查一次,比如
while{
try{ ...}
catch(InterruptException e){}
}
使用if线程被Interrupt后不检查直接执行后面可能报错。