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

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

公平锁、非公平锁

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

Synchronize也是一种非公平锁

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

Lock与UnLock方法一一对应;

自旋锁:spinlock

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

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

ReentrantLock和Synchronized

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

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

版权声明:本文为yutting原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/yutting/p/11492816.html