信息发布→ 登录 注册 退出

Java多线程之多种锁和阻塞队列

发布时间:2026-01-11

点击量:
目录
  • 一、悲观锁和乐观锁
    • 1.1. 乐观锁
    • 1.2. 悲观锁
  • 二、公平锁和非公平锁
    • 三、可重入锁(递归锁)
      • 四、自旋锁
        • 五、独占锁(写)/共享锁(读)
          • 六、什么是阻塞队列?
            • 七、阻塞队列(BlockingQueue)

              一、悲观锁和乐观锁

              1.1. 乐观锁

              顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。

              乐观锁适用于多读的应用类型,乐观锁在Java中是通过使用无锁编程来实现,最常采用的是CAS算法,Java原子类中的递增操作就通过CAS自旋实现的。

              CAS全称 Compare And Swap(比较与交换),是一种无锁算法。在不使用锁(没有线程被阻塞)的情况下实现多线程之间的变量同步。java.util.concurrent包中的原子类就是通过CAS来实现了乐观锁。

              1.2. 悲观锁

              总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁。

              二、公平锁和非公平锁


              三、可重入锁(递归锁)

              先看官网的解释翻译后的

              看不太懂,那么我们结合一下下面的案例就行了。

              两个同步方法01和02,都是被锁住的,当我们运行01的时候,一旦获取的01的锁,那么02的锁也可以被自动获取。

              补充:lock和unlock只要配对使用,就不会有问题。

              四、自旋锁

              其实CAS底层就是用 Unsafe类+CAS(自旋) 实现的,CAS底层有一个do while语句,循环比较在主存中的值是否等于期望值。

              五、独占锁(写)/共享锁(读)

              读归读,写归写,读和写可以同时进行。

              六、什么是阻塞队列?

              队列中放着数据,一个线程生产,一个线程获取。


              七、阻塞队列(BlockingQueue)

              阻塞队列有多少实现类呢?

              在线客服
              服务热线

              服务热线

              4008888355

              微信咨询
              二维码
              返回顶部
              ×二维码

              截屏,微信识别二维码

              打开微信

              微信号已复制,请打开微信添加咨询详情!