- class Test implements Runnable
- {
- private boolean flag;
- MyLock lock ;
- Test(boolean flag,MyLock lock) //讲 lock 作为参数 由构造器传入 这样就可以保证使用同一个 lock lock 下的对象也是相同的
- {
- this.flag = flag;
- this.lock =lock;
- }
- public void run()
- {
-
- if(flag)
- {
- while(true)
- {
- synchronized(lock.locka) //非静态lock.locka锁对象
- {
- System.out.println(Thread.currentThread().getName()+"...if locka ");
- synchronized(lock.lockb) //非静态lock.lockb锁对象
- {
- System.out.println(Thread.currentThread().getName()+"..if lockb");
- }
- }
- }
- }
- else
- {
- while(true)
- {
- synchronized(lock.lockb) //非静态lock.lockb锁对象
- {
- System.out.println(Thread.currentThread().getName()+"..else lockb");
- synchronized(lock.locka) //非静态lock.locka锁对象
- {
- System.out.println(Thread.currentThread().getName()+".....else locka");
- }
- }
- }
- }
- }
- }
- class MyLock
- {
- Object locka = new Object();
- Object lockb = new Object();
- }
- public class DeadLockTest
- {
- public static void main(String[] args)
- {
- MyLock lock = new MyLock();
-
-
- Thread t1 = new Thread(new Test(true,lock));
- Thread t2 = new Thread(new Test(false,lock));
- t1.start();
- t2.start();
- }
- }
复制代码 仔细看这里:Thread t1 = new Thread(new Test(true));
Thread t2 = new Thread(new Test(false));
你在创建线程时 新建了 两个 Test 对象,这两个对象里 创建的 Mylock 对象是不同的 ,当然无法锁住对方了。
要保证同步代码使用的是同一把锁 |