/** * * @描述: 读写锁:分为读锁和写锁,多个读锁不互斥,读锁与写锁互斥,写锁与写锁互斥,这是由JVM自己控制的,可以同时读,但不能同时写 那就上读锁; * 如果你的代码只读数据,可以有很多人同时读,但不能同时写那就上读锁. * 如果你的代码修改数据,只能有一个人在写,且不能同时写,那就上写锁 * * 总之,读的时候上读锁,写的时候上写锁,排他,我干的时候只有我能干,别人不能进来 * * @作者: Wnj . * @创建时间: 2017年5月16日 . * @版本: 1.0 . */ public class ReadWriteLockTest { /** * 产生三个线程写 * 三个线程读 * <功能详细描述> * @param args */ public static void main(String[] args) { final Queue3 q3 = new Queue3(); for (int i = 0; i < 3; i++) { //读 new Thread() { public void run() { while (true) { q3.get(); } } }.start(); //写 new Thread() { public void run() { while (true) { q3.put(new Random().nextInt(10000)); } } }.start(); } } } class Queue3 { private Object data = null;//共享数据,只能有一个线程能写该数据,但可以有多个线程读取它 ReadWriteLock rwl = new ReentrantReadWriteLock(); public void get() { rwl.readLock().lock(); try { System.out.println(Thread.currentThread().getName() + " ====start 准备读取data数据[可以被打乱]===="); Thread.sleep((long)(Math.random() * 1000)); System.out.println(Thread.currentThread().getName() + " ====end 读取data数据完毕[可以被打乱] ====" + data); } catch (InterruptedException e) { e.printStackTrace(); } finally { rwl.readLock().unlock(); } } public void put(Object data) { rwl.writeLock().lock(); try { System.out.println(Thread.currentThread().getName() + " ====start 准备写入data数据[不会被打乱]===="); Thread.sleep((long)(Math.random() * 1000)); this.data = data; System.out.println(Thread.currentThread().getName() + " ====end 写入data数据完毕[不会被打乱] ==== " + data); } catch (InterruptedException e) { e.printStackTrace(); } finally { rwl.writeLock().unlock(); } } }
时间: 2024-12-29 11:14:19