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


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

    公平锁和非公平锁

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

    可重入锁(递归锁)

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

    独占锁/共享锁

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

    自旋锁

    • 是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点就是循环会消耗CPU
  • 相关阅读:
    利用 Pandoc 将 Latex 转为 MS word 的方法
    CSS学习273~297(HTML5和CSS新特性)
    产品-Axure9(英文版),中继器(Repeater)实现表格内容的增删查改(CRUD)
    JVM篇---第九篇
    「容器管理系统」 1. 开篇:框架选型和环境搭建
    Redis相关
    JavaScript从入门到精通系列第二十三篇:JavaScript中的数组
    Day49-53 操作系统的中断、异常以及系统调用
    git初级
    【无标题】
  • 原文地址:https://blog.csdn.net/qq_43765199/article/details/126006610