您的位置:首页 > 编程语言 > Java开发

Java中的显示锁ReentrantLock使用时机

2011-08-27 12:46 429 查看
 

从Java 5.0开始,Java提供了访问共享对象的新机制:ReentrantLock。它实现了Lock接口:

  public interface Lock {

  void lock();

  void lockInterruptibly() throws InterrupttedException;

  boolean tryLock();

  boolean tryLock(long timeout, TimeUnitunit) throws InterruptedException;

  void unlock();

  Condition newCondition();

  }

  ReentrantLock提供了与synchronized相同的互斥和内存可见性的保证。获得ReentrantLock的锁与进入synchronized块有着相同的内存语义,释放ReentrantLock锁与退出synchronized块有相同的内存语义。

  那么为什么要创建与内存锁如此相似的机制呢?内存锁在大部分情况下能够很好的工作,但是有些功能上存在着局限:

  1)不能中断那些正在等待获取锁的进程,并且在请求锁失败的情况下,必须无限等待;

  2)内部锁必须在获取它们的代码块中被释放;这很好的简化了代码,但是在某些情况下,一个更灵活的加锁机制提供了更好的活跃度和性能。

  使用ReentrantLock的一般形式为:

  Lock lock = new ReentrantLock();

  ........

  lock.lock();

  try {

  //更新对象的状态

  //捕获异常,必要时恢复到原来的不变约束

  } finally {

  lock.unlock();        //锁必须在finally块中释放

  }

  《Java并发编程实践》一书给出了使用ReentrantLock的最佳时机:

  当你需要以下高级特性时,才应该使用:可定时的、可轮询的与可中断的锁获取操作,公平队列,或者非块结构的锁。否则,请使用synchronized。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java interface 编程 工作