Java中的锁分类

 Java中有很多的锁,但是并不全指锁,有些指锁的特性,设计,状态。

1.乐观锁

乐观锁认为在更新数据时,乐观的认为并发时并不会出现问题,即不加锁。

2.悲观锁

悲观锁认为多线程对同一个数据进行操作时,必定是会出问题的,悲观的认为必须加锁。

3.可重入锁

 

         可重入锁又称为递归锁,在外面已经获取了锁的同时,内部的方法还可以自动的获取锁,如上,如果不是可重入锁,就会产生死锁情况。ReentrantLock和Synchronized都是可重入锁

4.读写锁

读写锁的特点就是:读读不互斥,读写互斥,写写互斥。读写锁为的是A线程正在操作数据,然后线程B又来读数据,防止脏读。

5.分段锁

分段锁其实是一种思想,用于将数据分段,在每段上单独加锁,把锁进一步细粒度话,以提高并发效率。

6.自旋锁

自旋就是自己不断重试,当该线程没有抢占到锁时,还会继续不断的抢占,适用于当线程内任务比较小的情况,可大大提升锁的效率,但是由于不停的自旋,也会导致CPU资源的消耗。

7.共享锁和独占锁

共享锁是指该锁可被多个线程所持有,并发访问数据。比如:乐观锁

独占锁也叫互斥锁,同一时间只能被一个线程所持有。比如:Synchronized,ReentrantLock,ReadWriteLock(读写锁)。

8.公平锁和非公平锁

公平锁就是按照线程的顺序(先来后到)来分配锁,ReentrantLock可以通过设置改为公平锁

非公平锁就是不遵守先来后到,获取锁的机会不相同,Synchronized默认的ReentrantLock就是非公平锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值