写了小程度测试java死锁,代码如下。
我的疑问是:被锁定对象为什么要用static修饰呢?不用static就锁不住,不能出现死锁了。
public class TestDeadLock implements Runnable{
public int flag = 0;
static Object o1 = new Object(); static Object o2 = new Object();
public void run(){
System.out.println("flag=" + flag);
if(flag==1){
synchronized(o1){
try{
Thread.sleep(1500);
}catch(InterruptedException e){
e.printStackTrace();
}
synchronized(o2){
System.out.println("1");
}
}
}
if(flag==0){
synchronized(o2){
try{
Thread.sleep(1500);
}catch(InterruptedException e){
e.printStackTrace();
}
synchronized(o1){
System.out.println("0");
}
}
}
}
public static void main(String[] args){
TestDeadLock td1 = new TestDeadLock();
TestDeadLock td2 = new TestDeadLock();
td1.flag = 1;
td2.flag = 0;
Thread t1 = new Thread(td1);
Thread t2 = new Thread(td2);
t1.start();
t2.start();
}
}
不加static,TestDeadLock类在main方法中被new 了二次,td1和td2各自分别产生了o1,o2。run()方法去锁定时,也只能锁定td1和td2中各自的o1,o2对象
。加了 static后,TestDeadLock类无论new多少次,都只产生一个o1,一个o2对象。run()方法去锁定时,也就是锁定的唯一的,o1,o2.
因为是在线程中用synchronized,要想多个线程同步就需要是同一个对象,而static静态对象是线程共享的,如果没有static,创建的就是各个线程各自对象,就没法在线程之间共享了