Java并发编程中的ReentrantLock详解

 更新时间:2023年11月28日 11:26:16   作者:安然望川海  
这篇文章主要介绍了Java并发编程中的ReentrantLock详解,从Java 5 开始,引入了一个高级的处理并发的java.util.concurrent包,它提供了大量更高级的并发功能,能大大简化多线程程序的编写,需要的朋友可以参考下

Java ReentrantLock

从Java 5 开始,引入了一个高级的处理并发的java.util.concurrent包,它提供了大量更高级的并发功能,能大大简化多线程程序的编写。

我们知道Java语言直接提供了synchronized关键字用于加锁,但是这种锁一是很重,二是获取时必须一直等待,没有额外的尝试机制。

java.util.concurrent.locks包提供了ReentrantLock用于替换synchronized加锁,我们来看一下传统的synchronized代码:

public class Counter{
    private int count;
    public void add(int n){
        synchronized(this){
            count += n;
        }
    }
}

如果用ReentrantLock替代,可以把代码改造为:

public class Counter{
    private final Lock lock = new ReentrantLock();
    private int count;
    
    public void add(int n){
        lock.lock();
        try{
            count += n;
        }finally{
            lock.unlock();
        }
    }
}

因为synchronized是Java语言层面提供的语法,所以我们不需要考虑异常,而ReentrantLock是可重入锁,它和synchronized一样,一个线程可以多吃获取同一个锁。

和synchronized不同的是,ReentrantLock可以尝试获取锁:

if(lock.tryLock(1,TimeUnit.SECONDS)){
    try{
     ...   
    }finally{
        lock.unlock();
    }
}

上述代码在尝试获取锁的时候,最多等待1秒

后仍未获取到锁,tryLock()返回false,程序就可以做一些额外处理的,而不是无限等待下去。

所以,使用ReentranLock比直接使用synchronized更安全,线程在tryLock()失败的时候不会导致死锁。

到此这篇关于Java并发编程中的ReentrantLock详解的文章就介绍到这了,更多相关ReentrantLock详解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅析Spring Cloud Gateway中的令牌桶限流算法

    浅析Spring Cloud Gateway中的令牌桶限流算法

    这篇文章主要为大家浅析了Spring Cloud Gateway中的令牌桶限流算法原理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • 启动Tomcat报错Unsupported major.minor version xxx的解决方法

    启动Tomcat报错Unsupported major.minor version xxx的解决方法

    这篇文章主要为大家详细介绍了启动Tomcat报错Unsupported major.minor version xxx的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Java多线程工具篇BlockingQueue的详解

    Java多线程工具篇BlockingQueue的详解

    今天小编就为大家分享一篇关于Java多线程工具篇BlockingQueue的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • 详细分析JAVA 线程池

    详细分析JAVA 线程池

    这篇文章主要介绍了JAVA 线程池的的相关资料,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-06-06
  • java定时任务的实现方式

    java定时任务的实现方式

    这篇文章主要介绍了java定时任务的实现方式,在应用里经常都有用到在后台跑定时任务的需求,如何进行java定时任务,本文为大家进行讲解,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • Java中MapStruct使用方法解析

    Java中MapStruct使用方法解析

    这篇文章主要介绍了Java中MapStruct使用方法解析,接受请求参数都会使用一个vo类,这个vo类里封装了所有需要接受的参数,然后对参数进行业务逻辑处理,处理完后会持久化处理, 使用MapStruct可以快速帮你解决转换工作,需要的朋友可以参考下
    2023-10-10
  • SpringBoot整合Druid、Redis的示例详解

    SpringBoot整合Druid、Redis的示例详解

    Druid 是阿里巴巴开源平台上一个数据库连接池实现,结合了 C3P0、DBCP 等 DB 池的优点,同时加入了日志监控。这篇文章主要介绍了SpringBoot整合Druid、Redis的实例详解,感兴趣的朋友跟随小编一起看看吧
    2022-02-02
  • 剑指Offer之Java算法习题精讲字符串与二叉搜索树

    剑指Offer之Java算法习题精讲字符串与二叉搜索树

    跟着思路走,之后从简单题入手,反复去看,做过之后可能会忘记,之后再做一次,记不住就反复做,反复寻求思路和规律,慢慢积累就会发现质的变化
    2022-03-03
  • Java实现双色球抽奖随机算法示例

    Java实现双色球抽奖随机算法示例

    本篇文章主要介绍了Java实现双色球抽奖随机算法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Java多线程Future实现优雅获取线程的执行结果

    Java多线程Future实现优雅获取线程的执行结果

    这篇文章主要为大家详细介绍了Java如何利用Future实现优雅获取线程的执行结果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-07-07

最新评论