博客
关于我
Java并发编程知识点总结(十)——Java中的Lock概述
阅读量:773 次
发布时间:2019-03-24

本文共 1562 字,大约阅读时间需要 5 分钟。

Lock锁机制深入解析

一、Lock概述

在Java SE 5之后,Lock接口正式投入使用。通过以下简单示例可以直观理解其工作原理:

ReentrantLock lock = new ReentrantLock();lock.lock();try {    // 业务逻辑} finally {    lock.unlock();}

在SE 5之前,Java使用synchronized关键字实现锁机制,其特点是隐式加锁和解锁,而Lock接口则需要显式操作,加锁和解锁都需要程序员主动调用。此外,为了确保锁一定能解锁,lock.unlock()通常放在finally块中。

二、Lock接口

Lock接口提供了多种锁管理方法:

public interface Lock {    void lock();          // 加锁    void lockInterruptibly() throws InterruptedException;  // 可中断加锁    boolean tryLock();   // 非阻塞加锁    boolean tryLock(long time, TimeUnit unit) throws InterruptedException;  // 定时加锁    void unlock();         // 解锁    Condition newCondition();   // 创建条件wait}

接口定义了基本的加锁、解锁和等待机制,但实现类如ReentrantLock需自行实现细节。

三、ReentrantLock详解

3.1 类名说明
public class ReentrantLock implements Lock, java.io.Serializable

表示ReentrantLock实现了Lock接口并支持序列化。

3.2 锁实现原理

ReentrantLock通过Sync类构建锁机制。构造函数支持公平锁和非公平锁选择:

public ReentrantLock() {    sync = new NonfairSync();}public ReentrantLock(boolean fair) {    sync = fair ? new FairSync() : new NonfairSync();}

FairSyncNonfairSync继承自Sync,其中Sync又继承自AbstractQueuedSynchronizer(AQS)。AQS类是 synchronizedQueue的衍生类,主要用于实现锁的公平或非公平机制。

3.3 Sync类机制
static final class FairSync extends Syncstatic final class NonfairSync extends Sync

Sync中定义了关键同步操作,如enterexit。通过分析\AbstractQueuedSynchronizer可以发现,其核心是维护一个同步队列,用于线程协调。

四、总体理解

  • 锁与同步器的关系

    Lock(如ReentrantLock)是面向使用者的抽象,Primary用于定义使用者的交互逻辑,内部基于AQS实现并发控制。

  • AQS的核心机制

    AQS诸如提供了包括队列结构、挂起和唤醒操作等工具。具体实现通过组合多个AQS单元来完成更复杂的锁机制管理。

  • 重要方法解析

    • enter():尝试获取锁,挂起如果需要等待。
    • exit():释放锁,唤醒等待线程。
    • ooInit():初始化同步器。
  • 通过深入理解ReentrantLock的实现,能够更好地掌握Java多线程中的锁机制,为高并发程序优化奠定基础。

    转载地址:http://cbqkk.baihongyu.com/

    你可能感兴趣的文章
    mysql命令和mysql的配置文件
    查看>>
    watch
    查看>>
    MySQL命令行操作的相关语法
    查看>>
    MySQL命令行登陆,远程登陆MySQL
    查看>>
    mysql命令:set sql_log_bin=on/off
    查看>>
    mySQL和Hive的区别
    查看>>
    MySQL和Java数据类型对应
    查看>>
    mysql和oorcale日期区间查询【含左右区间问题】
    查看>>
    MYSQL和ORACLE的一些操作区别
    查看>>
    mysql和redis之间互相备份
    查看>>
    MySQL和SQL入门
    查看>>
    mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
    查看>>
    Mysql在Linux运行时新增配置文件提示:World-wrirable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored 权限过高导致
    查看>>
    Mysql在Windows上离线安装与配置
    查看>>
    MySQL在渗透测试中的应用
    查看>>
    Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
    查看>>
    Mysql在离线安装时提示:error: Found option without preceding group in config file
    查看>>
    MySQL基于SSL的主从复制
    查看>>
    Mysql基本操作
    查看>>
    mysql基本操作
    查看>>