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提供了两种读写锁,乐观读写锁与悲观读写锁,乐观读写锁读写不互斥,读操作在读数据前获取一个版本号,读完数据后校验版本号,如果版本号发生变更说明在读期间发生了写操作,可以重新再读一次或者获取悲观读锁重新读取数据。