嗨,我读过关于Java语言中的ReadWriteLock的文章,但我不确定我是否已经掌握了它的重入部分。下面是两个简短的代码示例,它们只使用一个主线程来显示重新进入
public class Locks {
public static void main( String[] args ) {
ReadWriteLock lock = new ReentrantReadWriteLock();
lock.writeLock().lock();
lock.readLock().lock();
System.out.println( "Reentrance acheieved" );
lock.readLock().unlock();
lock.writeLock().unlock();
}
}第二个例子
public class Locks {
public static void main( String[] args ) {
ReadWriteLock lock = new ReentrantReadWriteLock();
lock.readLock().lock();
lock.writeLock().lock();
System.out.println( "Reentrance acheieved" );
lock.writeLock().unlock();
lock.readLock().unlock();
}
}在第一个命令中执行sysout,但是在第二个命令中没有执行,这是为什么呢?这两个锁都是由同一个线程获得的,所以我们这里有一个重入的情况,但只有在首先获得写锁时才能进入,这很奇怪,因为在不可重入的情况下,doc说写操作与所有其他操作(无论是写操作还是读操作)是排他的。
发布于 2016-10-28 06:28:18
答案就在“可重入性”下面的文档中:
此锁允许读取器和写入器以ReentrantLock样式重新获取读或写锁定。在由写入线程持有的所有写锁定被释放之前,不允许不可重入的读取器。
此外,写入器可以获取读锁,但反之亦然。在其他应用程序中,当在调用或回调在读锁定下执行读取的方法期间保持写锁定时,可重入性可能很有用。如果读取器尝试获取写锁定,则永远不会成功。
https://stackoverflow.com/questions/40295018
复制相似问题