一、公平锁、非公平锁
公平锁指多个线程按照申请锁的顺序来获取锁,,即按等待获取锁的线程的等待时间进行获取,等待时间长的具有优先获取锁的权利;非公平锁就是没有顺序完全随机,所以能会造成优先级反转或者饥饿现象 。synchronized 就是非公平锁,ReentrantLock(使用 CAS 和 AQS 实现)通过构造参数可以决定是非公平锁还是公平锁,默认构造是非公平锁。非公平锁的吞吐量性能比公平锁好。
二、可重入锁
又名递归锁,指在同一个线程在外层方法获取锁的时候在进入内层方法会自动获取锁,synchronized 和 ReentrantLock 都是可重入锁,可重入锁可以在一定程度避免死锁。
三、独享锁、共享锁
独享锁是指该锁一次只能被一个线程持有,共享锁指该锁可以被多个线程持有。synchronized 和 ReentrantLock 都是独享锁,ReadWriteLock 的读锁是共享锁,写锁是独占锁。ReentrantLock 的独享锁和共享锁也是通过 AQS 来实现的。
四、互斥锁、读写锁
互斥锁,指的是一次最多只能有一个线程持有的锁。对于互斥锁,如果资源已被占用,资源申请者只能进入睡眠状态。互斥锁实质就是 ReentrantLock,读写锁实质就是 ReadWriteLock。