zoukankan      html  css  js  c++  java
  • 公平锁、非公平锁、可重入锁、递归锁、自旋锁

    公平锁:指多个线程按照申请锁的顺序来获取锁,先来后到。FIFO

    非公平锁:指多个线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁在高并发的情况下,有可能会造成优先级反转或者借现象。

    公平锁、非公平锁

    并发包中ReentranLock的创建可以指定构造函数的boolean类型来得到公平锁或者非公平锁,默认是非公平锁

    Synchronize也是一种非公平锁

    可重入锁也叫递归锁:指同一线程外层函数获得锁之后,内层递归函数仍然能获取该锁的代码。即为:线程可以进入任何一个它已经拥有的锁所同步着的代码块。

    Lock与UnLock方法一一对应;

    自旋锁:spinlock

    是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点是会消耗CPU

    独占锁:是指该所一次只能被一个线程锁持有。

    ReentrantLock和Synchronized

    共享锁:该锁可被多个线程所持有。

    ReentrantReadWriteLock其读锁是共享锁,其写锁是独占锁可保证并发读是非常高效的,读写,写读,写写的过程是互斥的。

  • 相关阅读:
    c#大圣之路笔记——c# 页面加载数据过长等待显示框
    Python(五)
    Python(四)
    Python(三)
    python(二)数据类型与变量
    初识Python
    Linux初识(九)
    Linux初识(八)正则表达式
    Linux基础初识(七)
    Linux基础初识(六)
  • 原文地址:https://www.cnblogs.com/yutting/p/11492816.html
Copyright © 2011-2022 走看看