多线程读写锁问题:创建读写锁,让多线程能同时读取数据,写写互斥,写读互斥

Java并发编程:使用读写锁实现多线程读写操作
该博客演示了如何在Java中使用ReentrantReadWriteLock实现读写锁,确保多线程环境下读取操作的并行性和写入操作的互斥。通过创建线程池并分配任务,展示了读写锁在高并发场景下的应用,以提高程序的效率。
部署运行你感兴趣的模型镜像
package com.qf.demo2;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * 读写锁问题:创建读写锁,让多线程能同时读取数据,写写互斥,写读互斥
 * @Author XZG
 * @Date: 2020/10/31 14:48
 * @Version 1.0
 */

public class WriteAndReadLockTest {
    public static void main(String[] args) {

        //创建新的线程池对象
        ExecutorService es1 = Executors.newFixedThreadPool(20);
        //创建新的读写锁
        WriteAndReadLock warl = new WriteAndReadLock();
        //获取开始的时间
        long startTime = System.currentTimeMillis();

        /*从线程池中拿出两个线程执行写入任务*/
        for (int i = 1; i <= 2; i++) {
            es1.submit(new Runnable() {
                @Override
                public void run() {
                    //调用读写锁的写入方法
                    warl.setNum(12);
                }
            });
        }

        /*从线程池中拿出两个线程执行读取任务*/
        for (int i = 1; i <= 18; i++) {
            es1.submit(new Runnable() {
                @Override
                public void run() {
                    //调用读写锁的读取方法
                    warl.getNum();
                }
            });
        }

        es1.shutdown();
        /*确保此时的线程池已经完全关闭*/
        while (true){
            if (es1.isTerminated()){
                long endTime = System.currentTimeMillis();
                long allTime = endTime - startTime;
                System.out.println(allTime);
                System.out.println("执行时间为" + allTime + "ms");
                break;
            }
        }
    }
}

创建读写锁类,声明读取和写入的方法,同时给读取写入上锁,确保写写互斥

package com.qf.demo2;

import java.util.concurrent.locks.ReentrantLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

/**
 *
 * @Author XZG
 * @Date: 2020/10/31 14:35
 * @Version 1.0
 */

public class WriteAndReadLock {

    //创建读写锁
    ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();
    //通过读写锁,获得读取锁
    ReentrantReadWriteLock.ReadLock rl = rwl.readLock();
    //通过读写锁,获得写入锁
    ReentrantReadWriteLock.WriteLock wl = rwl.writeLock();

    //声明一个变量
    public Integer num;

    public Integer getNum(){

        //给读取上锁
        rl.lock();
        try {
            Thread.sleep(1000);
        }
        catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("读取成功" + num);
        //给读取解锁
        rl.unlock();
        //返回读取到的值
        return num;
    }

    public void setNum(Integer num){

        //给写入上锁
        wl.lock();

        try {
            Thread.sleep(1000);
            //设置num
            this.num = num;
            System.out.println("设置成功");
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        //给写入解锁
        wl.unlock();
    }

}

运行结果图
在这里插入图片描述

您可能感兴趣的与本文相关的镜像

Kotaemon

Kotaemon

AI应用

Kotaemon 是由Cinnamon 开发的开源项目,是一个RAG UI页面,主要面向DocQA的终端用户和构建自己RAG pipeline

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值