更新时间:2023年05月29日09时43分 来源:传智教育 浏览次数:
是的,ReadWriteLock(读写锁)提供了读写操作之间的互斥。它允许多个线程同时进行读操作,但在写操作期间会阻塞其他线程的读和写操作。
接下来笔者通过一段具体的Java代码,来具体演示一下ReadWriteLock读写互斥的原理:
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class ReadWriteLockDemo {
private static final ReadWriteLock lock = new ReentrantReadWriteLock();
private static int sharedData = 0;
public static void main(String[] args) {
Thread writerThread = new Thread(() -> {
while (true) {
lock.writeLock().lock(); // 获取写锁
try {
sharedData++; // 修改共享数据
System.out.println("Writer thread modified data: " + sharedData);
Thread.sleep(1000); // 模拟写操作的耗时
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.writeLock().unlock(); // 释放写锁
}
}
});
Thread readerThread = new Thread(() -> {
while (true) {
lock.readLock().lock(); // 获取读锁
try {
System.out.println("Reader thread read data: " + sharedData); // 读取共享数据
Thread.sleep(500); // 模拟读操作的耗时
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.readLock().unlock(); // 释放读锁
}
}
});
writerThread.start();
readerThread.start();
}
}
在以上示例中,有一个共享的整数变量sharedData,一个写线程负责修改它的值,一个读线程负责读取它的值。
在写线程中,我们首先获取写锁lock.writeLock().lock(),然后进行写操作并修改共享数据,最后释放写锁lock.writeLock().unlock()。
在读线程中,我们首先获取读锁lock.readLock().lock(),然后进行读操作并打印共享数据,最后释放读锁lock.readLock().unlock()。
读线程和写线程都会一直运行,并通过锁的机制实现读写互斥。