当前位置:首页 > 开发 > 编程语言 > Java > 正文

Java 读写锁demo

发表于: 2014-09-11   作者:annan211   来源:转载   浏览次数:
摘要: java 读写锁 原理 和 实例 package thread; import java.util.ArrayList; import java.util.List; import java.util.Random; import java.util.concurrent.locks.ReentrantReadWriteLock; public class ReenRead
java 读写锁 原理 和 实例
package thread;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class ReenReadWriteLockDemo {

	public static void main(String[] args) {
		Data data = new Data();
		for(int i=0;i<3;i++){
			new Thread(new Reader(data)).start();

			new Thread(new Writer(data)).start();
		}
	}

}

class Data{
	private static final int length = 10;
	private  List<Integer> dataList = new ArrayList<Integer>(length);

	private ReentrantReadWriteLock lock = new ReentrantReadWriteLock();

	public void get(Data data){
		lock.readLock().lock();
		try {
			if(data.dataList.size()>0){
				System.out.println(Thread.currentThread().getName()+"--获取数据----"+data.dataList.remove(0));
			}
		}finally{
			lock.readLock().unlock();
		}
	}
	public void set(Data data){
		lock.writeLock().lock();
			try {
				if(data.dataList.size()<data.length){
				int num = new Random().nextInt(10000);
				dataList.add(num);
				System.out.println(Thread.currentThread().getName()+"--写入数据-------"+num);
				}
			}finally{
				lock.writeLock().unlock();
			}
	}
}

class Reader implements Runnable{
	private Data data;
	public Reader(Data data){
		this.data = data;
	}
	@Override
	public void run() {
		while(true)
		data.get(data);
	}
}

class Writer implements Runnable {
	private Data data;
	public Writer(Data data){
		this.data = data;
	}
	@Override
	public void run() {
		while(true)
		data.set(data);
	}
}





Java 读写锁demo

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
 1、概述   读写锁与互斥量类似,不过读写锁允许更高的并行性。互斥量要么是锁住状态,要么是不
读写锁在对资源进行保护的同时,还能区分想要读取资源值的线程(读取者线程)和想要更新资源的线程
读写锁在对资源进行保护的同时,还能区分想要读取资源值的线程(读取者线程)和想要更新资源的线程
开发过程中,我们玩玩需要大量与文件交互,读文件,写文件已成家常便饭,本地运行完美,但一上到投
有时,我们需要将更大的文件保存下来,就不能用手机内置的存储空间,毕竟是有限的,所以将文件保存
引用:http://www.ibm.com/developerworks/cn/linux/l-cn-rwspinlock1/index.html?ca=drs- 读写自旋
引用:http://www.ibm.com/developerworks/cn/linux/l-cn-rwspinlock3/ 基于简单共享变量的读写自旋
一、什么是锁 在Java的util.concurrent.locks包下有关于锁的接口和类如下: 先看一段代码: package
今天我来谈谈所有的PHPer都熟悉的session。 Case 1.示例代码中分别以files,redis储存会话数据 2./s
CORBA-Demo 扫盲连接: 1.http://blog.csdn.net/chjttony/article/details/6543116 2.http://blog
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号