写在前边: 在Java服务端中,会常常遇到并发的场景,以下我使用两个售票的案例实现传统的Lock锁与synchronized加锁解决线程安全问题。
本章代码:Gitee: juc.demo
一、Lock锁 ReentrantLock类: 可重用锁(公平锁|非公平锁)ReentrantReadWriteLock.ReadLock:读锁ReentrantReadWriteLock.WriteLock:写锁 二、锁的底层锁的底层有公平锁和非公平锁。其中:
公平锁 :十分公平,不能插队。非公平锁 :十分不公平,可以插队。(默认非公平锁) 三、案例 案例一:传统的synchronized实现 案例二:Lock锁的实现 四、Lock锁和synchronized的区别 snchronized是内置Java关键字;Lock是一个Java类。synchronized 无法判断获取锁的状态;Lock可以判断是否获取到了锁。(boolean b = lock.tryLock();)synchronized会自动释放锁;Lock必须要手动释放锁,如果不释放锁,死锁。synchronized线程1获得锁阻塞时,线程2会一直等待下去;Lock锁线程1获得锁阻塞时,线程2等待足够长的时间后中断等待,去做其他的事。synchronized可重入锁:不可以中断的,非公平;Lock可重入锁:可以判断锁,非公平(可以自己设置)。lock.lockInterruptibly();方法:当两个线程同时通过该方法想获取某个锁时,假若此时线程A获取到了锁,而线程B只有在等待,那么对线程B调用threadB.interrupt()方法能够中断线程B的等待过程。synchronized适合锁少量的代码同步问题; Lock适合锁大量的同步代码。到此这篇关于Java并发系列之JUC中的Lock锁与synchronized同步代码块的文章就介绍到这了,更多相关Java synchronized同步代码块内容请搜索七叶笔记以前的文章或继续浏览下面的相关文章希望大家以后多多支持七叶笔记!