ReentrantLock 与synchronized

1. ReentrantLock 通过方法 lock()与 unlock()来进行加锁与解锁操作,与 synchronized 会被 JVM 自 动解锁机制不同,ReentrantLock 加锁后需要手动进行解锁。为了避免程序出现异常而无法正常解 锁的情况,使用 ReentrantLock 必须在 finally 控制块中进行解锁操作。

2. ReentrantLock 相比 synchronized 的优势是可中断、公平锁、多个锁。这种情况下需要使用 ReentrantLock。

ReentrantLock 实现

public class MyService {
        private Lock lock = new ReentrantLock();
        //Lock lock=new ReentrantLock(true);//公平锁
        //Lock lock=new ReentrantLock(false);//非公平锁 private
        Condition condition = lock.newCondition();//创建 Condition public void

        testMethod() {
            try {
                lock.lock();//lock 加锁
                //1:wait 方法等待:
                //System.out.println("开始 wait"); condition.await();
                //通过创建 Condition 对象来使线程 wait,必须先执行 lock.lock 方法获得锁
                //:2:signal 方法唤醒
                condition.signal();//condition 对象的 signal 方法可以唤醒 wait 线程
                for (int i = 0; i < 5; i++) {
                    System.out.println("ThreadName=" + Thread.currentThread().getName() + (" " + (i +
                            1)));
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }
    }

你可能感兴趣的:(多线程,java,锁)