转载请注明出处:http://blog.csdn.net/xingjiarong/article/details/47947515
之前我们讲过ReentrantLock,这种锁不区分读操作和写操作,如果有一个线程在执行读操作,那么其他的所有的线程不能进行任何的读操作或者写操作。这样可以保证程序的互斥性,但是降低了程序的并发性,使执行效率降低,没有有效的发挥多线程的优势。比如说,有一个系统,主要是以读操作为主,比如有10个线程负责读数据,只有一个线程负责写数据。如果用我们之前的ReentrantLock方法,这10个线程中没有哪两个线程是可以同时执行的,但是我们仔细想一下,如果一个线程在执行读操作,那么其他的读线程可以执行吗?当然是可以的啊,因为读操作不会改变数据,自然不会造成数据错误,所以针对这种情况,java中有一个ReentrantReadWriteLock,用来控制读写操作。
这种锁分为两种,读锁和写锁。如果一个线程获得了读锁,那么其他的执行读操作的线程可以继续获得该读锁,也就是说读操作可以并发的执行,但是其他的写锁将会被阻塞。如果一个线程获得了写锁,那么其他的任何试图获得读锁和写锁的线程都将被阻塞。
我们来看一个例子:
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class ReadWrite {
private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
private Lock readLock;
private Lock writeLock;
private int num = -1;
public ReadWrite() {
readLock = lock.readLock();
writeLock = lock.writeLock();
}
public vo

本文介绍了Java中的ReentrantReadWriteLock,一种提高锁效率的机制。读写锁允许多个读线程并发执行,提高了多线程系统的性能,尤其在读操作频繁的场景下。当有写线程持有写锁时,其他读写线程会被阻塞,确保数据一致性。
提高锁的效率——使用读写锁&spm=1001.2101.3001.5002&articleId=47947515&d=1&t=3&u=8fe57f5c705f45e8a321407f3ed81050)
2203

被折叠的 条评论
为什么被折叠?



