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


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

    公平锁和非公平锁

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

    可重入锁(递归锁)

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

    独占锁/共享锁

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

    自旋锁

    • 是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点就是循环会消耗CPU
  • 相关阅读:
    2024022502-数据库绪论
    理解回归_多元线性回归_最大似然函数_最大密度函数_标准差_方差_数据离散程度---人工智能工作笔记0020
    51单片机学习:IO扩展(串转并)实验-74HC595
    网站推广常用的方式
    辅助驾驶功能开发-上游需求篇(8)-地平线J2感知性能解析
    【MySQL】MySQL数据类型
    【深入理解C++】左值引用、常引用、右值引用、std::move()函数
    意外发现一款很好用的开源BI工具——DataEase
    给你两个集合,要求{A} + {B}
    笔记 | 嵌入式系统概论
  • 原文地址:https://blog.csdn.net/qq_43765199/article/details/126006610