多线程条件通行工具——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 ...
随机推荐
- 【AR实验室】OpenGL ES绘制相机(OpenGL ES 1.0版本)
0x00 - 前言 之前做一些移动端的AR应用以及目前看到的一些AR应用,基本上都是这样一个套路:手机背景显示现实场景,然后在该背景上进行图形学绘制.至于图形学绘制时,相机外参的解算使用的是V-SLA ...
- 如何用百度MIP快速搭建体验友好的移动页面
在读这篇文章之前,请确定你已经了解MIP定义及加速原理.如果不确定的话,可以到MIP官网了解. 改造前期准备和注意事项: 你可以选择直接将原先的移动站点直接改成MIP站,也可以单独再做一套MIP站点与 ...
- ADO.NET对象的详解
1. Connection 类 和数据库交互,必须连接它.连接帮助指明数据库服务器.数据库名字.用户名.密码,和连接数据库所需要的其它参数.Connection对象会被Command对象使用,这样就能 ...
- Java8实战分享
虽然很多人已经使用了JDK8,看到不少代码,貌似大家对于Java语言or SDK的使用看起来还是停留在7甚至6. Java8在流式 or 链式处理,并发 or 并行方面增强了很多,函数式的风格使代码可 ...
- 【Win 10 应用开发】启动远程设备上的应用
这个功能必须在“红石-1”(build 14393)以上的系统版中才能使用,运行在一台设备上的应用,可以通过URI来启动另一台设备上的应用.激活远程应用需要以下前提: 系统必须是build 14393 ...
- JavaScript常见的五种数组去重的方式
▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...
- .net Elasticsearch 学习入门笔记
一. es安装相关1.elasticsearch安装 运行http://localhost:9200/2.head插件3.bigdesk插件安装(安装细节百度:windows elasticsear ...
- 代码的坏味道(16)——纯稚的数据类(Data Class)
坏味道--纯稚的数据类(Data Class) 特征 纯稚的数据类(Data Class) 指的是只包含字段和访问它们的getter和setter函数的类.这些仅仅是供其他类使用的数据容器.这些类不包 ...
- JavaWeb——Servlet
一.基本概念 Servlet是运行在Web服务器上的小程序,通过http协议和客户端进行交互. 这里的客户端一般为浏览器,发送http请求(request)给服务器(如Tomcat).服务器接收到请求 ...
- java时间
Calendar.getInstance().getTime() 获取当前时间(包括星期和时区 CST China Standard Time): Fri Jan 06 21:03:36 CST 2 ...