Java中有很多的锁,但是并不全指锁,有些指锁的特性,设计,状态。
1.乐观锁
乐观锁认为在更新数据时,乐观的认为并发时并不会出现问题,即不加锁。
2.悲观锁
悲观锁认为多线程对同一个数据进行操作时,必定是会出问题的,悲观的认为必须加锁。
3.可重入锁
可重入锁又称为递归锁,在外面已经获取了锁的同时,内部的方法还可以自动的获取锁,如上,如果不是可重入锁,就会产生死锁情况。ReentrantLock和Synchronized都是可重入锁。
4.读写锁
读写锁的特点就是:读读不互斥,读写互斥,写写互斥。读写锁为的是A线程正在操作数据,然后线程B又来读数据,防止脏读。
5.分段锁
分段锁其实是一种思想,用于将数据分段,在每段上单独加锁,把锁进一步细粒度话,以提高并发效率。
6.自旋锁
自旋就是自己不断重试,当该线程没有抢占到锁时,还会继续不断的抢占,适用于当线程内任务比较小的情况,可大大提升锁的效率,但是由于不停的自旋,也会导致CPU资源的消耗。
7.共享锁和独占锁
共享锁是指该锁可被多个线程所持有,并发访问数据。比如:乐观锁
独占锁也叫互斥锁,同一时间只能被一个线程所持有。比如:Synchronized,ReentrantLock,ReadWriteLock(读写锁)。
8.公平锁和非公平锁
公平锁就是按照线程的顺序(先来后到)来分配锁,ReentrantLock可以通过设置改为公平锁。
非公平锁就是不遵守先来后到,获取锁的机会不相同,Synchronized和默认的ReentrantLock就是非公平锁。