更新时间: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()。
读线程和写线程都会一直运行,并通过锁的机制实现读写互斥。