• 公平锁、非公平锁、可重入锁、递归锁、自旋锁谈谈你的理解?


    公平锁、非公平锁、可重入锁、递归锁、自旋锁谈谈你的理解?

    公平锁和非公平锁

    • 公平锁:是指多个线程按照申请锁的顺序来获取锁,类似排队打饭,先来后到
    • 非公平锁:是指多个线程获取的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁;在高并发的情况下,有可能会造成优先级反转或者饥饿现象
    • 并发包中ReentrantLock的创建可以指定构造函数的boolean类型来得到公平锁或非公平锁,默认是非公平锁
    • 两者区别
      1. 公平锁:就是很公平,在并发环境中,每个线程在获取锁时会先查看此锁维护的等待队列,如果为空,或者当前线程是等待队列的第一个,就占用锁,否则就会加入到等待队列中,以后就会安照FIFO的规则从队列中取到自己
      2. 非公平锁比较粗鲁,上来就直接尝试占有锁,如果尝试失败,就会采取类似公平锁那种方式
    • Java ReentrantLock而言,通过构造函数指定该锁是否是公平锁,默认是非公平锁,非公平锁的优点在于吞吐量比公平锁大
    • 对于Synchronized而言,也是一种非公平锁

    可重入锁(递归锁)

    • 指的是同一线程外层函数获得锁之后,内层递归函数仍然能获取该锁的代码。在同一个线程在外层方法获取锁的时候,在进入内层方法会自动获取锁
    • 也及时说,线程可以进入任何一个他已经拥有的锁所同步这的代码块
    • ReentrantLock/Synchronized就是一个典型的课重入锁
    • 可重入锁最大的作用是避免死锁

    独占锁/共享锁

    • 独占锁:指该锁一次只能被一个线程所持有。对ReentrantLock和Synchronized而言都是独占锁
    • 共享锁:指该锁可以被多个线程持有
    • 对ReentrantReadWriteLock其读锁是共享锁,其写锁是独占锁
    • 读锁的共享锁可以保证并发度是非常高效的,读写,写读,写写的过程是互斥的

    自旋锁

    • 是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点就是循环会消耗CPU
  • 相关阅读:
    cv2.imread无法读取图片
    【翻译】Style Transfer by Relaxed Optimal Transport and Self-Similarity
    Excel怎么批量生成文件夹
    以太网 TCP协议(TCP报文交互后的状态机变化)
    SpringMVC:整合SSM框架
    从零开始的力扣刷题记录-第八十九天
    【编码问题】使用 http 请求,中文乱码问题
    Java-方法的详解( 看完之后,我不允许还有人不懂!)
    学习阿里如何进行数据指标体系的治理
    Mybatis 映射器中使用@InsertProvider,@UpdateProvider,@DeleteProvider,@SelectProvider
  • 原文地址:https://blog.csdn.net/qq_43765199/article/details/126006610