并发编程之Lock


lock是java concurrent locks包下提供的锁机制,已经有了sychronized后为什么还需要Lock呢?

sychronized缺陷

1.在同一时刻只能有一个线程时执行同步代码,不能区分读写,并发性不高。
2.如果获取锁线程在执行较长时间的io操作或正在sleep,其他线程只能持续等待。

sychronized与lock区别

1.sychronized是java内置关键只,Lock是一个类,通过这个类实现同步访问。
2.sychronized锁操作获取与释放都是jvm操作,不需要担心锁忘记释放问题,lock是需要手动获取锁与释放锁,如果不注意未释放锁容易造成死锁,一般情况下载finally块中释放锁。
3.Lock提供了灵活的api方法,lock(同步等待锁),lockinterruptibly(其他线程调用interrupt()方法时终止获取锁),tryLock()尝试获得锁,成功立即返回true,不成功立即返回false。tryLock(long time,TimeUnit)在指定时间范围内等待获取锁,如果成功获取锁返回true,如果未能获取锁停止退出获取锁,返回false。
unlock()释放锁,newCondition()获取一个Condition条件对象。

lock实现类

ReentranLock:
Lock的一个实现,可重入锁,可中断锁,公平锁,非公平锁,底层通过Unsafe类的cas操作实现锁机制。

ReadWriteLock:读写锁接口
ReentrantReadWriteLock :ReadWriteLock的一个实现,可以获取读写锁。
StampedLock:对ReentrantReadWriteLock 的改进,ReentrantReadWriteLock 读写完全互斥,在读多写少的场景写线程有可能会被饿死。StampedLock提供了两种读写锁,乐观读写锁与悲观读写锁,乐观读写锁读写不互斥,读操作在读数据前获取一个版本号,读完数据后校验版本号,如果版本号发生变更说明在读期间发生了写操作,可以重新再读一次或者获取悲观读锁重新读取数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值