1. 悲观锁:当一天线程去获取锁之后,另一个线程来获取锁会阻塞等待,常见的synchronized就是悲观锁
2. 乐观锁:当一天线程去操作的时候,其他的线程也可以操作,操作提交是根据版本控制的,CAS就是乐观锁,通过比较预期值与实际值的比较考虑是否提交更新。悲观锁适合写场景多的情况,乐观锁适合读场景多的情况
3. 公平锁:所有线程都能公平的获取到锁,线程申请锁之后会排队到一个线程组里,根据申请顺序去获取锁的使用
4. 非公平锁:不是所有线程都能拿到锁,当一个线程去请求的时候可能直接插队拿到了锁,有一些线程可能会饿死,常用的synchronized、ReentrantLock
5. 可重入锁:在使用锁之后还可以申请获取锁
6. 不可重入锁:在获取锁之后不可在内部重新获取锁
小结:可重入锁能一定程度的避免死锁 synchronized、ReentrantLock 重入锁
7. 自旋锁:在获取锁的时候如果有其他线程占用锁,那么该线程就会一直循环去获取锁,一直到获取到为止
8. 共享锁:一个线程占用锁之后,其他线程可以读数据,但不能修改\新增\删除数据
9. 互斥锁:一个线程占用锁之后,其他线程不可以进行任何操作
10. 死锁:两个或两个以上的线程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法让程序进行下去