626
1、公平选择性,支持非公平和公平锁获取,吞吐量不公平优于公平。
2、重进入,读锁和写锁都支持线程重进入。
3、锁降级,遵循获取写锁、获取读锁、释放写锁的顺序,写锁可以降级为读锁。
实例
publicclassReadWriteLockTest{ publicstaticvoidmain(String[]args){ finalQueueq=newQueue(); for(inti=0;i<3;i++){ newThread(){ @Override publicvoidrun(){ while(true){ q.get(); .start(); newThread(){ @Override publicvoidrun(){ while(true){ q.put(newRandom().nextInt(10000)); .start(); classQueue{ //共享数据,只能有一个线程能写该数据,但可以有多个线程同时读该数据。 ReadWriteLockrwl=newReentrantReadWriteLock(); privateObjectdata=null;//共享数据,只能有一个线程能写数据,但可以有多个线程读该数据 publicvoidget(){ //上读锁,其他线程只能读不能写 rwl.readLock().lock(); try{ System.out.println(Thread.currentThread().getName()+"bereadytoreaddata!"); Thread.sleep((long)(Math.random()*1000)); System.out.println(Thread.currentThread().getName()+"havereaddata:"+data); catch(InterruptedExceptione){ e.printStackTrace(); finally{ rwl.readLock().unlock(); publicvoidput(Objectdata){ //上写锁,不允许其他线程读也不允许写 rwl.writeLock().lock(); try{ System.out.println(Thread.currentThread().getName()+"bereadytowritedata!"); Thread.sleep((long)(Math.random()*1000)); this.data=data; System.out.println(Thread.currentThread().getName()+"havewritedata:"+data); catch(InterruptedExceptione){ e.printStackTrace(); finally{ rwl.writeLock().unlock();