zoukankan      html  css  js  c++  java
  • ReadWriteLock 读写锁(读书笔记)

     读写分离锁可以有效的帮助减少锁的竞争,提升系统的效率,
    • 读-读不互斥 读读之间不阻塞
    • 读-写互斥 读阻塞写,写也会阻塞读
    • 写-写互斥 写写阻塞 
    在系统中,读操作次数远远大于写操作,则读写锁就可以发挥最大的功效,提升系统的性能.
    public class ReadWriteLockDemo {
        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 handleWrite(Lock lock, int index) throws InterruptedException {
            try {
                lock.lock();
                Thread.sleep(1000);
                this.value = index;
            } finally {
                lock.unlock();
            }
        }
    
        public static void main(String[] args) {
            final ReadWriteLockDemo demo = new ReadWriteLockDemo();
            Runnable readRunnable = () -> {
                try {
                    Object o = demo.handleRead(readLock);//读写锁
                    // Object o1 = demo.handleRead(lock);//普通锁
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            };
            Runnable writeRunnable = () -> {
                try {
                    demo.handleWrite(writeLock, new Random().nextInt());//读写锁
                    //demo.handleWrite(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();
            }
        }
    }
     
    我们分别使用重入锁和读写锁,耗时有明显的减少!
  • 相关阅读:
    在线用户数与并发用户数的区别和比例关系
    MYSQL中数据类型介绍
    5分钟教你搞定RAID模式
    nginx与fastdfs配置详解与坑
    Fastdfs group通过添加硬盘扩容
    fastDfs配置文件tracker.conf配置详解
    FastDFS配置详解之Storage配置
    mysql修改库名
    vCenter Server Appliance(VCSA )6.7部署指南
    如何知道一个函数的执行时间简单案例
  • 原文地址:https://www.cnblogs.com/ten951/p/6212139.html
Copyright © 2011-2022 走看看