天天看點

JUC入門系列(十)-ReadWriteLock讀寫鎖

一、讀寫鎖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