deadlock.md

截图


死锁4条件

互斥条件: 某时刻某资源每次只能被一个进程使用
占有并等待条件:一个进程至少占有一个资源,并等待另一资源,因请求资源而阻塞时,对已获得的资源保持不放
非抢占条件:进程已获得的资源,在末使用完之前,不能强行剥夺;资源不能抢占,只能在进程完成后自动释放。
循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系,资源被下一个进程占有,循环。

死锁原因

runnable函数中,run函数输出(Inside B.last()),而又有另一个线程进行着计数,计数到达count结束时输出(Inside A.last())。
我们知道,当一个线程访问object的一个synchronized(this)同步代码块时,其他线程对object中所有其它synchronized(this)同步代码块的访问将被阻塞。

现在后台的线程被调度到运行t.start()时才会开始运行run里的代码,即输出(Inside B.last()),而同时计数结束时就会输出(Inside A.last()),如果在计时结束时,刚好两个synchronized代码块都要运行,那么就会由于互斥性互不相让,程序无法输出,产生了死锁。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容