A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 天火传说 中级黑马   /  2015-6-2 21:59  /  285 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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.竞争共享资源


2 个回复

倒序浏览
过来学习一下,如果LZ把注释写上,再格式化排一下序那就相当不错了:)
回复 使用道具 举报
死锁其实就是两个A,B进程,两把X,Y锁,A进程拿了X锁等待Y锁,B进程拿了Y锁等待X锁,这样
形成死锁
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马