多线程条件通行工具——AbstractQueuedSynchronizer
本文原创,转载请注明出处!
参考文章:
AbstractOwnableSynchronizer,用于供子类存取独占锁的所属线程。
- #getExclusiveOwnerThread()/#setExclusiveOwnerThread(Thread):获取/设置独占锁的所属线程。
AbstractQueuedSynchronizer/AbstractQueuedLongSynchronizer,用于操纵独占锁与共享锁,由子类提供线程获取锁与释放锁的策略,制定线程通行的条件。前者是操纵int,后者是操纵long。
状态
state由子类来赋于具体意义,可以作为一个锁的状态或其它意义。
- #getState():int
获取状态。 - #setState(int)
设置状态。 - #compareAndSetState(int, int):boolean
尝试设置状态,返回是否设置成功。
独占锁
相关操作:
- acquire(int)
获取独占锁。 - acquireInterruptibly(int)
获取独占锁,可中断。 - tryAcquireNanos(int, long):boolean
获取独占锁,可中断,可超时,返回true表示操作成功,false表示操作失败。 - #tryAcquire(int):boolean
尝试获取独占锁,返回是否可以出队还是继续排队,供子类实现。 - release(int):boolean
释放独占锁,返回是否操作成功。 - #tryRelease(int):boolean
尝试释放独占锁,返回是否可以唤醒下一个线程,供子类实现。 - Collection<Thread> getExclusiveQueuedThreads()
返回队列中需要获取独占锁的所有线程。 - #boolean isHeldExclusively()
查看当前线程是否为独占锁所属线程,供子类实现。
操作流程:

共享锁
相关操作:
- acquireShared(int)
获取共享锁。 - acquireSharedInterruptibly(int)
获取共享锁,可中断。 - tryAcquireSharedNanos(int, long):boolean
获取共享锁,可中断,可超时,返回true表示操作成功,false表示操作失败。 - #tryAcquireShared(int):int
尝试获取共享锁,返回大于或等于0表示可以出队,否则表示继续排队,供子类实现。 - releaseShared(int):boolean
释放共享锁,返回是否操作成功。 - #tryReleaseShared(int):boolean
尝试释放共享锁,返回是否可以唤醒下一个线程,供子类实现。 Collection<Thread> getSharedQueuedThreads()
返回队列中需要获取共享锁的所有线程。
操作流程:

队列
相关操作:
- int getQueueLength()
返回队列的长度 - boolean hasQueuedThreads()
返回队列中是否有线程 - Collection<Thread> getQueuedThreads()
返回队列中所有线程 - Collection<Thread> getExclusiveQueuedThreads()
返回队列中需要获取独占锁的所有线程 - Collection<Thread> getSharedQueuedThreads()
返回队列中需要获取共享锁的所有线程 - boolean isQueued(Thread)
查看指定线程是否位于队列中 - boolean hasQueuedPredecessors()
返回当前线程是否不位于队头,一般公平策略的子类需要使用到这个方法。 - Thread getFirstQueuedThread()
返回排于队头的线程。 - boolean hasContended()
查看是否曾经有线程入过队
条件
ConditionObject是一个内部类,其实现接口是Condition,供子类实现时选择是否提供创建。
相关操作:
- boolean owns(ConditionObject)
查看目标条件对象是否所属该AbstractQueuedSynchronizer对象 - boolean hasWaiters(ConditionObject)
查看是否有等待目标条件的线程 - int getWaitingThreads(ConditionObject)
查看等待目标条件的线程数量 - Collection<Thread> getWaitQueueLength(ConditionObject)
返回等待目标条件的所有线程
多线程条件通行工具——AbstractQueuedSynchronizer的更多相关文章
- 多线程条件通行工具——CountDownLatch
CountDownLatch的作用是,线程进入等待后,需要计数器达到0才能通行. CountDownLatch(int)构造方法,指定初始计数. await()等待计数减至0. await(long, ...
- 多线程条件通行工具——CyclicBarrier
CyclicBarrier的作用是,线程进入等待后,需要达到一定数量的等待线程后,再一次性开放通行. CyclicBarrier(int, Runnable)构造方法,参数1为通行所需的线程数量,参数 ...
- 多线程条件通行工具——Semaphore
Semaphore的作用是,限制线程通行的数量,如果线程进入时达到通行数量,便等待其它正在通行的线程释放. acquire()获取通行 release()释放通行 availablePermits() ...
- 多线程IP获取工具(C#)
以前帮一个朋友写的“IP采集工具”! Control.CheckForIllegalCrossThreadCalls = false; 多线程,测试后还比较稳定. 500线程时候,CPU5%左右,内存 ...
- Linux 多线程条件变量同步
条件变量是线程同步的另一种方式,实际上,条件变量是信号量的底层实现,这也就意味着,使用条件变量可以拥有更大的自由度,同时也就需要更加小心的进行同步操作.条件变量使用的条件本身是需要使用互斥量进行保护的 ...
- C++11并发——多线程条件变量std::condition_variable(四)
https://www.jianshu.com/p/a31d4fb5594f https://blog.csdn.net/y396397735/article/details/81272752 htt ...
- posix多线程--条件变量
条件变量是用来通知共享数据状态信息的. 1.条件变量初始化两种方式:(1)静态初始化pthread_cond_t cond = PTHREAD_COND_INITIALIZER;代码示例如下: #in ...
- 使用java多线程分批处理数据工具类
最近由于业务需要,数据量比较大,需要使用多线程来分批处理,提高处理效率和能力,于是就写了一个通用的多线程处理工具,只需要实现自己的业务逻辑就可以正常使用,现在记录一下 主要是针对大数据量list,将l ...
- linux下多线程断点下载工具-axel
今天要下载一下14G左右的文件,用wget约10小时,后来发现linux下有个多线程支持断点续传的下载工具axel,试了一下,下载速度大大增加. 包地址:http://pkgs.repoforge.o ...
随机推荐
- 平台之大势何人能挡? 带着你的Net飞奔吧!
镇楼图: 跨平台系列: Linux基础 1.Linux基础学习 By dnt http://www.cnblogs.com/dunitian/p/4822807.html 环境配置 1.Hyper-v ...
- 在.NET Core 里使用 BouncyCastle 的DES加密算法
.NET Core上面的DES等加密算法要等到1.2 才支持,我们可是急需这个算法的支持,文章<使用 JavaScriptService 在.NET Core 里实现DES加密算法>需要用 ...
- hadoop 2.7.3本地环境运行官方wordcount-基于HDFS
接上篇<hadoop 2.7.3本地环境运行官方wordcount>.继续在本地模式下测试,本次使用hdfs. 2 本地模式使用fs计数wodcount 上面是直接使用的是linux的文件 ...
- 【原】AFNetworking源码阅读(二)
[原]AFNetworking源码阅读(二) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中我们在iOS Example代码中提到了AFHTTPSessionMa ...
- mybatis_基础篇
一.认识mybatis: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改 ...
- MAVEN学习-第一个Maven项目的构建
MAVEN安装成功之后就可以进行项目的构建和管理了: 为什么要用maven进行项目的构建和管理? 对于初学者来说一个最直接的也是最容易里的优点在于JAR包的管理,相对于以前开发一个项目的时候我们需要用 ...
- [C#] C# 知识回顾 - 表达式树 Expression Trees
C# 知识回顾 - 表达式树 Expression Trees 目录 简介 Lambda 表达式创建表达式树 API 创建表达式树 解析表达式树 表达式树的永久性 编译表达式树 执行表达式树 修改表达 ...
- css居中div的几种常用方法
在开发过程中,很多需求需要我们居中一个div,比如html文档流当中的一块div,比如弹出层内容部分这种脱离了文档流等.不同的情况有不同的居中方式,接下来就分享下一下几种常用的居中方式. 1.text ...
- 【踩坑速记】开源日历控件,顺便全面解析开源库打包发布到Bintray/Jcenter全过程(新),让开源更简单~
一.写在前面 自使用android studio开始,就被它独特的依赖方式:compile 'com.android.support:appcompat-v7:25.0.1'所深深吸引,自从有了它,麻 ...
- 深入理解CSS六种颜色模式
前面的话 赏心悦目的颜色搭配让人感到舒服,修改元素颜色的功能让人趋之若鹜.但颜色规划不当,会让网站用户无所适从.颜色从<font color="">发展至今,保留了很多 ...