内置锁的缺点:
- 一个线程因为等待内置锁而进入阻塞之后,就无法中断该线程了;
- 尝试获得内置锁时,无法设置超时;
- 获得内置锁,必须使用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