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

本文深入探讨Java中的内置锁与ReentrantLock的区别,包括锁的可中断性、超时设置及条件变量的使用方法。同时介绍了原子变量的概念及其在Atomic包中的具体应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

内置锁的缺点:

  • 一个线程因为等待内置锁而进入阻塞之后,就无法中断该线程了;
  • 尝试获得内置锁时,无法设置超时;
  • 获得内置锁,必须使用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.youkuaiyun.com/leeds1993/article/details/52738845

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值