1、按锁的性质分
1)公平锁/非公平锁
公平锁:线程按申请锁的顺序一次获取锁;
非公平锁:不按顺序,线程可以抢占;
2)独享锁/共享锁
独享锁:锁一次只能被一个线程访问;
共享锁:锁可以被多个线程访问;
3)乐观锁/悲观锁
乐观锁:假定不发生冲突,只在提交操作时检测是否违反数据完整性;
悲观锁:假定会发生冲突,屏蔽一切可能违反数据完整性的操作;
4)可重入锁
同一个线程在外层方法获取锁的时候,进入内层方法会自动获取锁;
2、按设计方案分
1)自旋锁
尝试获取锁的线程不会立即阻塞,会循环地尝试获取锁;
优点:减少线程上下文切换的消耗;
缺点:消耗CPU;
2)偏向锁/轻量级锁/重量级锁
偏向锁:一段同步代码一直被一个线程所访问,该线程会自动获取锁,降低获取的代价;
轻量级锁:锁是偏向锁时,被另一个线程访问,升级为轻量级锁,其他线程自旋地尝试获取锁,不阻塞,提高性能;
重量级锁:锁是轻量级锁时,另一个线程自旋一定次数获取锁就进入阻塞,变为重量级锁,其他申请线程进入阻塞,性能降低;
3)分段锁
并发操作,让锁的粒度变小;
常见的锁
1)Synchronized:非公平、悲观、独享、互斥、可重入
2)RentrantLock:默认非公平、可以变公平、悲观、独享、可重入、重量级
3)ReentrantReadWriteLock:默认非公平、可以变公平、悲观、写独享、读共享、可重入、重量级