Javaのロック-WriteReadLock
4213 ワード
あるデータに対してスレッドの安全な読み書き操作を行うには、ロックを利用してスレッドの同期を行う必要があります.習慣的な方法は、読むときにロックをかけ、他の読み書き操作を禁止し、書くときは、他の読み書き操作を禁止することです.では、読み書きロックは、より細かくロックする操作です.読むときは、他のスレッドの読み取り操作を許可したり、他のスレッドの書き込み操作を禁止したりします.具体的には以下の表にまとめられています.
-
読み取り
書き込み
読み取り
ノンブロッキング
ブロッキング
書き込み
ブロッキング
ブロッキング
極端な例では、システム内の書き込み回数が読み取り回数よりはるかに小さい場合、これは読み書きロックの利点をより際立たせることができます.
読み書き操作に時間がかかると仮定し、読み書き操作ごとに1秒かかります.
mainメソッドでは,2つのforループを行い,それぞれ18個のリードスレッド,2個のライトスレッドを起動する.プログラムの読み方、書き方にはそれぞれ1つの注釈があり、通常ロックと読み書きロックで、読み書きロックで2秒で実行が完了し、通常ロックでは20秒かかることを示しています.
-
読み取り
書き込み
読み取り
ノンブロッキング
ブロッキング
書き込み
ブロッキング
ブロッキング
極端な例では、システム内の書き込み回数が読み取り回数よりはるかに小さい場合、これは読み書きロックの利点をより際立たせることができます.
public class WriteReadLockDemo {
private static Lock lock = new ReentrantLock();
private static ReentrantReadWriteLock readWriteLock = new ReentrantReadWriteLock();
private static Lock readLock = readWriteLock.readLock();
private static Lock writeLock = readWriteLock.writeLock();
private int value;
public Object handleRead(Lock lock) throws InterruptedException {
try {
lock.lock();
Thread.sleep(1000);
return value;
} finally {
lock.unlock();
}
}
public void handdleWrite(Lock lock, int index) throws InterruptedException {
try {
lock.lock();
Thread.sleep(1000);
value = index;
} finally {
lock.unlock();
}
}
public static void main(String[] args) {
WriteReadLockDemo writeReadLockDemo = new WriteReadLockDemo();
Runnable readRunnable = () -> {
try {
//
// writeReadLockDemo.handleRead(readLock);
writeReadLockDemo.handleRead(lock);
} catch (InterruptedException e) {
e.printStackTrace();
}
};
Runnable writeRunnable = () -> {
try {
//
// writeReadLockDemo.handdleWrite(writeLock, new Random().nextInt());
writeReadLockDemo.handdleWrite(lock, new Random().nextInt());
} catch (InterruptedException e) {
e.printStackTrace();
}
};
for (int i = 0; i < 18; i++) {
new Thread(readRunnable).start();
}
for (int i = 18; i < 20; i++) {
new Thread(writeRunnable).start();
}
}
}
読み書き操作に時間がかかると仮定し、読み書き操作ごとに1秒かかります.
mainメソッドでは,2つのforループを行い,それぞれ18個のリードスレッド,2個のライトスレッドを起動する.プログラムの読み方、書き方にはそれぞれ1つの注釈があり、通常ロックと読み書きロックで、読み書きロックで2秒で実行が完了し、通常ロックでは20秒かかることを示しています.