锁分类
可重入锁、不可重入锁
- 可重入锁:某个线程获得了A锁后,如果A锁里面的代码还需要继续获得A锁,那么就可以获得继续执行。
举例:synchronized、ReentrantLock、ReentrantReadWriteLock - 不可重入锁:某个线程获得了A锁后,如果A锁里面的代码还需要继续获得A锁,那么就不能获得,直接死锁了。
当前Java就只有一个地方有,线程池源码里面的Wroker类是的。
乐观锁、悲观锁
- 乐观锁:当前线程不能获取锁资源,可以让cpu继续获取锁资源。举例:CAS(Atomic)
- 悲观锁:当前线程不能获取锁资源,那么就会被挂起(BLOCKED、WAITING),这样就涉及到了jvm与os的切换,很消耗资源的。举例:synchronized、ReentrantLock、ReentrantReadWriteLock
公平锁、非公平锁
- 公平锁:当线程A获取到锁,然后线程B不能获取到锁,B排队,然后线程C不能获取到锁,C排队。只有等B获取到并释放锁或者B取消了获取锁,C才能去获取。举例:ReentrantLock、ReentrantReadWriteLock
- 非公平锁:当线程A获取到锁,然后线程B不能获取到锁,B排队,然后线程C来获取锁,就先去抢一波,能抢到美滋滋,抢不到的话,就乖乖排队了。其实也不是那么的不公平。举例:synchronized、ReentrantLock、ReentrantReadWriteLock
互斥锁、共享锁
- 互斥锁:同一时间只有一个线程能获取这把锁。举例:synchronized、ReentrantLock、ReentrantReadWriteLock(写锁)
- 共享锁:同一时间可以有多个线程获得这把锁。举例:ReentrantReadWriteLock(读锁)