黑马程序员--线程同步工具

本文深入探讨了Java并发编程中Lock接口的使用方法,包括ReentrantLock的加锁与解锁操作,以及读写锁的实现原理与应用场景。通过具体示例说明了如何利用读写锁优化缓存系统的效率,并介绍了Condition、Semaphore、CyclicBarrier等并发工具类的作用。
摘要由CSDN通过智能技术生成
---------------------- android培训java培训、期待与您交流! ----------------------


Lock

Lock lock = newReentrantLock();

lock()

用来取得对象的锁定。

unlock()

用来释放对象的锁定,通常由同一个Lock对象来调用lock()与unlock()。

 

读写锁

       多个读锁不互斥,读锁和写锁互斥,写锁和写锁互斥。

读写锁模拟缓存例子:

public ObjectgetData(String key){

       rwl.readLock().lock();//上读锁

       Object value = null;

       try{

           value = cache.get(key);//获取数据

           if(value==null){//如果没有

              rwl.readLock().unlock();//解开读锁

              rwl.writeLock().lock();//上写锁

              try {

                  if(value==null){//判断数据是否已存在,防止已有线程进入第一层判断,被打断后重写数据             

                     value = "aaa";

                  }

              } finally {

                  rwl.writeLock().unlock();//解开写锁

              }

              rwl.readLock().lock();//还原成读锁

           }         

       }finally{

           rwl.readLock().unlock();//释放读锁

       }

       return value;

    }

Condition的功能类似传统线程技术中的Object.wait和Object.notify的功能

    Lock lock = new ReentrantLock();      

Condition condition =lock.newCondition();

……

condition.await();

      ……

condition.signal();

Semaphore实现信号灯                                                                                

Semaphore可以维护当前访问自身的线程数,并提供了同步机制。实现Semaphore可以控制同时访问资源的线程数,例如,实现一个允许的并发访问数。

CyclicBarrier

表示大家彼此等待,大家集合好后才开始出发,分散活动后又在指定地点集合碰面。

CountDownLatch

   计数器到达零后,线程开始运行。

Exchanger

   用于实现两个人直接的数据交换,每个人在完成一定的事物后想与对方交换数据,第一个先拿出数据的人将一直等待第二个人拿着数据到来时,才能彼此交换数据。

---------------------- android培训java培训、期待与您交流!

 ----------------------详细请查看:http://edu.csdn.net/heima

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值