Java-ReentrantReadWriteLock的简单例子

原创 2015年07月07日 20:42:41

内容:读锁时共享的,写锁时互斥的(可见运行结果),都是通过AQS实现的。

public class ReentrantReadWriteLockTest {
	
	static class MyObject {
		private Object object;
		private ReadWriteLock lock = new ReentrantReadWriteLock();
		
		public void get() {
			lock.readLock().lock();
			System.out.println(Thread.currentThread().getName() + "准备读数据!!");
			
			try {
				Thread.sleep(new Random().nextInt(1000));
				System.out.println(Thread.currentThread().getName() + "读数据为:" + this.object);
			} catch (InterruptedException e) {
				e.printStackTrace();
			} finally {
				lock.readLock().unlock();
			}
		}
		
		public void put(Object object) {
			lock.writeLock().lock();
			System.out.println(Thread.currentThread().getName() + "准备写数据");
			
			try {
				Thread.sleep(new Random().nextInt(1000));
				this.object = object;
				System.out.println(Thread.currentThread().getName() + "写数据为" + this.object);
			} catch (InterruptedException e) {
				e.printStackTrace();
			} finally {
				lock.writeLock().unlock();
			}
		}
	}
	
	public static void main(String[] args) throws InterruptedException {
		final MyObject myObject = new MyObject();
		ExecutorService executor = Executors.newCachedThreadPool();
		
		for (int i = 0; i < 3; i++) {
			executor.execute(new Runnable() {
				
				@Override
				public void run() {
					for (int j = 0; j < 5; j++)
						myObject.put(new Random().nextInt(1000));
				}
			});
		}
		
		for (int i = 0; i < 3; i++) {
			executor.execute(new Runnable() {
				
				@Override
				public void run() {
					for (int j = 0; j < 5; j++)
						myObject.get();
				}
			});
		}
		
		executor.shutdown();
	}

}


运行结果:



版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Java线程池类ThreadPoolExecutor、ScheduledThreadPoolExecutor及Executors工厂类

Java中的线程池类有两个,分别是:ThreadPoolExecutor和ScheduledThreadPoolExecutor,这两个类都继承自ExecutorService。利用这两个类,可以创建...

多线程详解java.util.concurrent

一、多线程 1、操作系统有两个容易混淆的概念,进程和线程。 进程:一个计算机程序的运行实例,包含了需要执行的指令;有自己的独立地址空间,包含程序内容和数据;不同进程的地址空间是互相隔离的;...

Java多线程(十)之ReentrantReadWriteLock深入分析

一、ReentrantReadWriteLock与ReentrantLock   说到ReentrantReadWriteLock,首先要做的是与ReentrantLock划清界限。它和...

java线程系列---读写锁ReentrantReadWriteLock

获取顺序 此类不会将读取者优先或写入者优先强加给锁定访问的排序。但是,它确实支持可选的公平 策略。当公平地构造线程时,线程利用一个近似到达顺序的策略来争夺进入。当释放写入锁定后,将写入锁定分配给等待...

喻红叶《Java并发-ReentrantReadWriteLock源码分析》

ReentrantLock实现了标准的互斥重入锁,任一时刻只有一个线程能获得锁。考虑这样一个场景:大部分时间都是读操作,写操作很少发生;我们知道,读操作是不会修改共享数据的,如果实现互斥锁,那么即使都...

[java并发]读写锁ReentrantReadWriteLock里面的FairSync 和 NonfairSync

背景介绍 最近转行做java后台了,对于java的并发完全不熟悉,于是到网上各种搜资料。 接到的一个任务是一个很简单从数据库里面读取一些表到内存里面,然后做一个缓存。 读数据库用的EJB3的En...

java 共享锁和ReentrantReadWriteLock

ReadWriteLock 和 ReentrantReadWriteLock介绍ReadWriteLock,顾名思义,是读写锁。它维护了一对相关的锁 — — “读取锁”和“写入锁”,一个用于读取操作,...

【Java并发编程实战】—–“J.U.C”:ReentrantReadWriteLock

ReentrantLock实现了标准的互斥操作,也就是说在某一时刻只有有一个线程持有锁。ReentrantLock采用这种独占的保守锁直接,在一定程度上减低了吞吐量。在这种情况下任何的“读/读”、“读...

Java多线程系列--“JUC锁”08之 共享锁和ReentrantReadWriteLock

Java多线程系列-目录 [笔记][Java7并发编程实战手册]系列目录概要Java的JUC(java.util.concurrent)包中的锁包括”独占锁”和”共享锁”。 在“Java多线程系...

Java多线程探究-读写锁ReentrantReadWriteLock

读写锁实际是一种特殊的自旋锁,它把对共享资源的访问者划分成读者和写者,读者只对共享资源进行读访问,写者则需要对共享资源进行写操作。这种锁相对于自旋锁而言,能提高并发性,因为在多处理器系统中,它允许同时...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)