一、讀寫鎖ReadWriteLock
- ReadWriteLock 維護了一堆相關的鎖,一個用于隻讀操作,另一個用于寫入操作。隻要沒有writer,讀取鎖可以由多個reader線程同時保持。寫入鎖是獨占的。
- ReadWriteLock 讀取操作通常不會改變共享資源,但執行寫入操作時,必須獨占方式來擷取鎖。對于讀操作占多數的資料結構,ReadWriteLock能提供比獨占鎖更高的并發性。而對于隻讀的資料結構,其中包含的不變性可以完全不需要考慮加鎖操作。
二、Demo
package com.yuxx.juc;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class TestReadWriteLock {
public static void main(String[] args) {
ReadWriteLockDemo rw = new ReadWriteLockDemo();
new Thread(new Runnable() {
@Override
public void run() {
rw.set((int)(Math.random() *101));
}
},"Write").start();
for (int i = 1; i <= 100; i++) {
new Thread(new Runnable() {
@Override
public void run() {
rw.get();
}
},"Read").start();
}
}
}
class ReadWriteLockDemo{
private int number = 0;
private ReadWriteLock lock = new ReentrantReadWriteLock();
public void get() {
lock.readLock().lock();
try {
System.out.println(Thread.currentThread().getName() + ":" + number);
} finally {
lock.readLock().unlock();
}
}
public void set(int number) {
lock.writeLock().lock();
try {
System.out.println(Thread.currentThread().getName());
this.number = number;
} finally {
lock.writeLock().unlock();
}
}
}
三、ynchronized相比讀寫鎖的缺點
synchronized存在一個問題:讀與讀互斥。一般讀操作不會産生修改,那麼讀/讀、讀/寫之間的不互斥性就會大大提高并發效率。
轉載于:https://my.oschina.net/alexjava/blog/3083569