美文网首页
deadlock.md

deadlock.md

作者: Mikeday | 来源:发表于2016-11-10 13:24 被阅读0次

    截图


    死锁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代码块都要运行,那么就会由于互斥性互不相让,程序无法输出,产生了死锁。

    相关文章

      网友评论

          本文标题:deadlock.md

          本文链接:https://www.haomeiwen.com/subject/frukuttx.html