java读写锁

实现高并发情况下,多线程读和读不互斥,读和写互斥,写和写互斥,代码如下:

package threadLock;

import java.util.Random;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class ReadWriterLockTest {

    public void init() {
        final Queue queue = new Queue();

        //开启三个读的线程
        for (int i = 0; i < 3; ++i) {
            new Thread(new Runnable() {

                @Override
                public void run() {
                    while(true){
                        queue.readData();
                    }
                }
            }).start();
        }
        //开启三个写的线程
        for (int i = 0; i < 3; ++i) {
            new Thread(new Runnable() {

                @Override
                public void run() {
                    while(true)
                        queue.writerData();
                }
            }).start();
        }
    }

    class Queue {
        private Integer data; // 多线程操作的资源

        ReadWriteLock rwl = new ReentrantReadWriteLock();  //读写锁,读和读不互斥,读和写互斥,读和读互斥
        
        public void readData() {
            try {
                rwl.readLock().lock();  //上读锁,线程只能做读操作
                System.out.println(Thread.currentThread().getName()
                        + " ready to read");
                Thread.sleep(300);
                System.out.println(Thread.currentThread().getName()
                        + "has read data is " + data);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally{
                rwl.readLock().unlock(); //释放读锁
            }
        }

        public void writerData() {
            try {
                rwl.writeLock().lock();  //上写锁,只能当前线程执行
                System.out.println(Thread.currentThread().getName()
                        + " ready to write");
                Thread.sleep(300);
                this.data = new Random().nextInt(10000);
                System.out.println(Thread.currentThread().getName()
                        + "has write data is " + data);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally{
                rwl.writeLock().unlock(); //释放写锁
            }
        }
    }

    public static void main(String[] args) {
        new ReadWriterLockTest().init();
    }
}

 

posted @ 2017-01-13 17:27  风的低吟  阅读(150)  评论(0编辑  收藏  举报