ReentrantReadWriteLock的实现原理
阅读数:82 评论数:0
跳转到新版页面分类
python/Java
正文
一、概述
只要没有写入,读取锁可以由多个读线程同时保持,但写锁是独占的。
公平性 | 支持公平锁和非公平锁的获取,非公平锁的吞吐量优于公平锁,默认是非公平锁 |
可重入 | 线程获取读锁之后能哆再次获取读锁,但不能获取写锁;而线程获取写锁后,可以再次获取写锁或读锁 |
锁降级 | 线程获取写锁之后获取读锁,再释放写锁,这样写锁变为读锁 |
二、基本原理
ReentrantReadWriteLock 内部也是通过 队列同步器AQS 实现的,AQS有一个同步状态state,高16位记录读锁的状态,低16位记录写锁的状态。
相关推荐
1、直接常量
为了编译器可以准确的知道要生成什么样的类型,可以给直接常量后面添加后缀字符标志它的类型,若为L表示long,F表示float,D表示double。也可以利用前缀表示进制,0x表示十六进制
一、类的继承
1、说明
(1)extends关键字用于类的继承。
(2)在C++中,方法的动态绑定是使用virtual关键字来实现的,而在Java中,动态绑定是默认的形为,不需要添加额外的关键字。
(
一、创建线程
创建线程有四种方式:继承Thread类、实现Runnable接口、实现Callable接口、通过线程池创建。
1、继承Thread
重写run方法。
class A extends Th
一、Collection接口
Collection接口的iterator和toArray方法都用于获得集合中的“所有元素”。前者返回一个“iterator”对象,后者返回一个包含集合中所有元素的数组。
1.hashCode的存在主要用于查找的快捷性,如hashtable,hastmap等,hashcode是用来在散列存储结构中确定对象的存储地址的。
2.如果两个对象相同,就是适用