java.util.concurrent.locks.Lock类的lock和lockInterruptibly方法的区别

什么是可中断的锁获取呢?就是:线程在等待获取锁的过程中,是否能够响应中断,以便在被中断的时候能够解除阻

状态,而不是傻傻地一直在等待。java对象的内置锁(synchronized)就是一种不可中断的锁,也就是说如果一个线

程在等待获取某个对象的内置锁,就算是该线程被其他线程中断,该线程仍然继续等待内置锁,而不是解除阻塞状

态,也不抛出InterruptedException。Lock类的lock()类似synchronized,是不可中断的,在等待获取锁的过程中,

不响应中断请求;lockInterruptibly是可中断的,线程在等待获取锁的过程中,能够响应中断并抛出异常。

public static void testLock() throws Exception
{
    final Lock lock = new ReentrantLock();

    Thread t1 = new Thread(new Runnable()
    {
        @Override
        public void run()
        {
            // 1.测试lock
            // lock.lock();

            // 2.测试lockInterruptibly
            try
            {
                lock.lockInterruptibly();
            }
            catch (InterruptedException e)
            {
                System.out.println(" interrupted.");
            }

        }
    });

    // 占用锁的时候,让t1开始运行
    lock.lock();
    t1.start();

    Thread.sleep(100);
    t1.interrupt();
}

可以分别注释1和2处的代码,进行测试。调用lock.lock()发现线程t1一直不能结束,即t1一直在等待获取锁;调用lock.

lockInterruptibly()发现t1线程能够终止,并打印interrupted,即响应了线程中断请求。

你可能感兴趣的:(java并发编程)