可重入锁的获取和释放须要注意的一点儿事

什么是可重入锁,不可重入锁呢?"重入"字面意思已经非常明显了,就是能够又一次进入。可重入锁,就是说一个线程在

取某个锁后,还能够继续获取该锁,即同意一个线程多次获取同一个锁。比方synchronized内置锁就是可重入的

,假设A类有2个synchornized方法method1和method2,那么method1调用method2是同意的。

显然重入锁给编程带

来了极大的方便。假如内置锁不是可重入的,那么导致的问题是:1个类的synchornized方法不能调用本类其它

synchornized法,也不能调用父类中的synchornized方法。与内置锁相应,JDK提供的显示锁ReentrantLock也是可

以重入的,这里主要说下可重入锁的释放须要的事儿。

public static void main(String[] args) throws Exception
{
    final ReentrantLock lock = new ReentrantLock();

    Thread t = new Thread(new Runnable()
    {
        @Override
        public void run()
        {
            lock.lock();
            System.out.println("execute");
            lock.unlock();
        }
    });

    lock.lock();
    lock.lock();
    t.start();

    Thread.sleep(200);
    System.out.println("realse one once");

    lock.unlock();
}

上面的代码会出现死锁。由于主线程2次获取了锁,可是却仅仅释放1次锁,导致线程t永远也不能获取锁。一个线程获

多少次锁,就必须释放多少次锁。这对于内置锁也是适用的,每一次进入和离开synchornized方法(代码块),就是

一次完整的锁获取和释放。

原文地址:https://www.cnblogs.com/gavanwanggw/p/6879708.html