1、概念
可重入的读写锁,读写锁内部维护了一个ReadLock和一个WriteLock,底层还是AQS,但是AQS只有一个state状态量,如何同时控制读和写呢,这里使用了state(int)的高16位表示读状态,低16为表示写,高16位的值代表获取读锁的线程数,低16位代表写锁的可重入数。
2、原理
利用CAS+AQS队列来实现。它支持公平锁和非公平锁,两者的实现类似
3、实例
public class ReentrantDemo implements Runnable { Lock lock = new ReentrantLock(); @Override public void run() { set(); } public void set() { try { lock.lock(); System.out.println("set 方法"); get(); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock();// 必须在finally中释放 } } public void get() { try { lock.lock(); System.out.println("get 方法"); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock(); } } public static void main(String[] args) { ReentrantDemo reentrantDemo = new ReentrantDemo(); new Thread(reentrantDemo).start(); } }
以上是分析ReentrantLock的重入特性的Java测试示例的详细内容。更多信息请关注PHP中文网其他相关文章!