黑马程序员技术交流社区

标题: 死锁分析 [打印本页]

作者: 天火传说    时间: 2015-6-2 21:59
标题: 死锁分析
class Test implements runnable
{private boolean flag;
Test(boolean flag){
this.flag=flag;
}
public void run()
{if(flag)
{synchronized(Mylock.locka)
{system.out.println("if locka");
{synchronized(Mylock.lockb)
{system.out.println("if lockb");
}}}
else{
synchronized(Mylock.lockb){
system.out.println("else lockb");
synchronized(Mylock.locka){
system.out.println("else locka");
}}}}}
class Mylock{
static Object locka=new Object();
static Object lockb=new Object();
}
class deadlockTest{
public static void main(String[] args){
Thread t1=new Thread(new Test(true));
Thread t2=new Thread(new Tset(false))
t1.start();
t2.start();
}
}
死锁分析:
1.进程推进顺序不当
2.竞争共享资源



作者: Tangtang    时间: 2015-6-2 23:30
过来学习一下,如果LZ把注释写上,再格式化排一下序那就相当不错了:)
作者: Amu    时间: 2015-6-2 23:42
死锁其实就是两个A,B进程,两把X,Y锁,A进程拿了X锁等待Y锁,B进程拿了Y锁等待X锁,这样
形成死锁




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2