第2章 线程与锁-2.3 超越内置锁

来源:互联网 发布:欧美时尚杂志 知乎 编辑:程序博客网 时间:2024/06/08 07:58

内置锁的缺点:

  • 一个线程因为等待内置锁而进入阻塞之后,就无法中断该线程了;
  • 尝试获得内置锁时,无法设置超时;
  • 获得内置锁,必须使用synchronized块;

synchronized其实是一个语法糖,等价于

synchronized(this){}

与synchronized不同的是,ReentranLock提供了显示的lock和unlock方法。

形式如下

Lock lock  = new ReentranLock();lock.lock();try{}finally{    lock.unlock();}

可中断的锁

使用lockInterruptibly()方法可以让线程中止。

超时

使用trylock()方法可以为加锁操作设置超时时间。

交替锁

书中以链表为例,对节点单独加锁,这样就不会影响未被操作节点的访问。
这里写图片描述

条件变量
用于等待某个事件的发生,建议按以下模式使用

ReentrantLock lock = new ReentrantLock();Condition con = new Condition();lock.lock();try{    while(!<条件为真>)  //如果用if的话可能会造成虚假唤醒        condition.await();}finally{    lock.unlock();}

原子变量
在Atomic包里一共有12个类,四种原子更新方式,分别是原子更新基本类型,原子更新数组,原子更新引用和原子更新字段。Atomic包里的类基本都是使用Unsafe实现的包装类。

原子更新基本类型类

用于通过原子的方式更新基本类型,Atomic包提供了以下三个类:

AtomicBoolean:原子更新布尔类型。
AtomicInteger:原子更新整型。
AtomicLong:原子更新长整型。

Java中的Atomic包使用指南 http://ifeve.com/java-atomic/

相关阅读:
reentrantreadwritelock http://www.cnblogs.com/liuling/archive/2013/08/21/2013-8-21-03.html
虚假唤醒 http://blog.csdn.net/leeds1993/article/details/52738845

原创粉丝点击