公平锁、非公平锁、可重入锁、递归锁、自旋锁
公平锁:指多个线程按照申请锁的顺序来获取锁,先来后到。FIFO
非公平锁:指多个线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁在高并发的情况下,有可能会造成优先级反转或者借现象。
公平锁、非公平锁
并发包中ReentranLock的创建可以指定构造函数的boolean类型来得到公平锁或者非公平锁,默认是非公平锁
Synchronize也是一种非公平锁
可重入锁也叫递归锁:指同一线程外层函数获得锁之后,内层递归函数仍然能获取该锁的代码。即为:线程可以进入任何一个它已经拥有的锁所同步着的代码块。
Lock与UnLock方法一一对应;
自旋锁:spinlock
是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点是会消耗CPU
独占锁:是指该所一次只能被一个线程锁持有。
ReentrantLock和Synchronized
共享锁:该锁可被多个线程所持有。
ReentrantReadWriteLock其读锁是共享锁,其写锁是独占锁。可保证并发读是非常高效的,读写,写读,写写的过程是互斥的。