JavaSE-多线程(8)- ReadWriteLock

JavaSE-多线程(8)- ReadWriteLock

以下例子中多个线程同时对count进行读写,读方法和写方法都等待1秒,并且读写方法都使用了ReentrantLock重入锁,通过CountDownLatch工具类让主线程等待读写线程结束,最后程序输出执行时间为12秒左右

例1

package com.hs.example.base.multithread.day01;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class ReadWriteTest {
    private volatile int count;
    private Lock lock;

    public ReadWriteTest(Lock lock) {
        this.lock = lock;
    }

    public void accumulate() {
        try {
            lock.lock();
            Thread.sleep(1000);
            count++;
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
    }

    public int getCount() {
        try {
            lock.lock();
            Thread.sleep(1000);
            System.out.println(Thread.currentThread().getName() + " : " + this.count);
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
        return this.count;
    }

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        CountDownLatch countDownLatch = new CountDownLatch(12);
        Lock lock = new ReentrantLock();
        ReadWriteTest readWriteTest = new ReadWriteTest(lock);

        for (int i = 0; i < 2; i++) {
            new Thread(() -> {
                readWriteTest.accumulate();
                countDownLatch.countDown();
            }).start();
        }

        for (int i = 0; i < 10; i++) {
            new Thread(() -> {
                readWriteTest.getCount();
                countDownLatch.countDown();
            }).start();
        }
        try {
            countDownLatch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("耗时:" + (System.currentTimeMillis() - start));
    }
}

Thread-2 : 2
Thread-3 : 2
Thread-4 : 2
Thread-5 : 2
Thread-6 : 2
Thread-7 : 2
Thread-8 : 2
Thread-9 : 2
Thread-10 : 2
Thread-11 : 2
耗时:12060

例2 是对例1 的改造,从输出结果可见,多线程执行读写时间为 3 秒左右,在此例中,使用 ReentrantReadWriteLock 读写锁,当读取count值时使用 readLock 读锁,写入count数据时使用 writeLock 写锁,由输出结果可知,读取数据的线程几乎在同一时间执行,可见,当读操作较多时,读写锁可提高效率

例2

package com.hs.example.base.multithread.day01;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class ReadWriteTest2 {
    private volatile int count;

    public void accumulate(Lock lock) {
        try {
            lock.lock();
            Thread.sleep(1000);
            count++;
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
    }

    public  int getCount(Lock lock) {
        try {
            lock.lock();
            Thread.sleep(1000);
            System.out.println(Thread.currentThread().getName() + " : " + this.count);
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
        return this.count;
    }

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        CountDownLatch countDownLatch = new CountDownLatch(12);
        ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
        ReadWriteTest2 readWriteTest = new ReadWriteTest2();

        for (int i = 0; i < 2; i++) {
            new Thread(() -> {
                readWriteTest.accumulate(readWriteLock.writeLock());
                countDownLatch.countDown();
            }).start();
        }

        for (int i = 0; i < 10; i++) {
            new Thread(() -> {
                readWriteTest.getCount(readWriteLock.readLock());
                countDownLatch.countDown();
            }).start();
        }

        try {
            countDownLatch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("耗时:" + (System.currentTimeMillis() - start));
    }
}
Thread-7 : 2
Thread-5 : 2
Thread-3 : 2
Thread-11 : 2
Thread-9 : 2
Thread-4 : 2
Thread-8 : 2
Thread-10 : 2
Thread-6 : 2
Thread-2 : 2
耗时:3060
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值