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


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

    公平锁和非公平锁

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

    可重入锁(递归锁)

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

    独占锁/共享锁

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

    自旋锁

    • 是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点就是循环会消耗CPU
  • 相关阅读:
    MySQL——自增长
    Linux——环境变量与地址空间
    1.1.8 外键
    了解 异常
    [Linux] Network: IPv6 link-local 地址是否可用不自动生成
    单片机判断语句与位运算的坑
    十一、数据结构——多路查找树
    零距离揭秘绝地求生:玩家最关心的吃鸡要领和细节全攻略!
    【CSDN 每日一练 ★☆☆】【蛮力/双指针】删除排序链表中的重复元素
    Ajax学习:解决跨域_JSONP
  • 原文地址:https://blog.csdn.net/qq_43765199/article/details/126006610