非常的抱歉,犹豫自己学艺不精,妄下结论,贻笑大方。在我更新完测试用例之后发现,在x.wait()方法之后,当前线程进入的是timed_waiting或者waiting状态时,释放的是当前x的锁资源,并不会释放其余的锁资源,所以还是会造成死锁。给大家带来的疑惑,深感歉意。
讲高并发必须讲线程,线程到底是什么东西呢,我们查看Thread代码的时候发现一段很神奇的代码
调用了native的方法,在jvm中代表本地方法,一般是C++实现的,所以跟踪不到具体实现
具体讲讲Thread的6个状态吧:
New:新建并没有执行start方法
Runnable:start方法执行之后,executing 或者 waiting for other resource
Blocked:waiting for a monitor lock 执行过 ,一般是为了进入同步块,同步方法,同步类时,不释放资源,会造成死锁
Waiting:当执调用Object.wait()不带时间参数时,调用Thread.join()不带事件参数时,或者LockSupport.park()方法时,进入此状态