1公平锁/非公平锁
公平锁:线程按照申请顺序依次获取锁。
非公平锁:线程获取锁的优先顺序不是按照申请顺序。优点:吞吐量大。
注:ReentrantLock和Synchronized都是非公平锁,但ReentrantLock可以通过构造函数成为公平锁。
2可重入锁
指某线程获取某方法的锁,该方法内部调用其它有锁的方法,该线程可以直接获取内部方法的锁。
注:ReentrantLock和Synchronized都是可重入锁。
3独享锁/共享锁
独享锁指锁只能被一个线程所拥有。
共享锁指锁可以被多个线程拥有。
注:ReentrantLock和Synchronized都是独享锁,ReadWriteLock是共享锁。
4乐观锁/悲观锁
乐观锁指认为操作某一条数据时,该数据是最新的,同一时间有且只有一个操作源,乐观的认为不加锁的并发是安全的。多用于读比较多的操作。
悲观锁指认为操作某一条数据时,该数据不是最新的,同一时间有多个操作圆,悲观的认为不加锁的并发是不安全的。多用于写比较多的操作。
5偏向锁/轻量级锁/重量级锁
这三种指锁的状态,并且是针对Synchronized。
偏向锁是指一段同步代码一直被一个线程访问,那么该线程会自动获取锁,降低获取锁的代价。
轻量级锁是指当锁是偏向锁的时候,被另一个线程所访问,偏向锁就会升级为轻量级锁,其他线程会通过自旋的形式尝试获取锁,不会阻塞,提高性能。
重量级锁是指当锁为轻量级锁的时候,另一个线程虽然是自旋,但自旋不会一直持续下去,当自旋一定次数的时候,还没有获取到锁,就会进入阻塞,该锁膨胀为重量级锁。重量级锁会让其他申请的线程进入阻塞,性能降低。
6自旋锁
在Java中,自旋锁是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点是循环会消耗CPU。