Java并发编程之Semaphore(信号量)详解及实例
概述
通常情况下,可能有多个线程同时访问数目很少的资源,如客户端建立了若干个线程同时访问同一数据库,这势必会造成服务端资源被耗尽的地步,那么怎样能够有效的来控制不可预知的接入量呢?及在同一时刻只能获得指定数目的数据库连接,在JDK1.5 java.util.concurrent 包中引入了Semaphore(信号量),信号量是在简单上锁的基础上实现的,相当于能令线程安全执行,并初始化为可用资源个数的计数器,通常用于限制可以访问某些资源(物理或逻辑的)的线程数目。例如我们可以将一个信号量初始化为可获得的数据库连接个数。一旦某个线程获得了信号量,可获得的数据库连接数减1。线程消耗完资源并释放该资源时,计数器就会加1。当信号量控制的所有资源都已被占用时,若有线程试图访问此信号量,则会进入阻塞状态,直到有可用资源被释放。简单理解就是:如去银行办理业务,只有6个窗口,所以可同时给6个客户办理业务,其他客户只能等待,当有其中一个窗口办理完业务时就会通知下一个客户办理。
主要html" target="_blank">方法
1、构造方法
Semaphore提供了一个带有boolean参数的构造方法,true代表公平锁,false代表非公平锁,默认实现是非公平锁
2、普通方法
3、 我们来模拟客户在银行办理业务的场景示例
import java.util.Random; import java.util.concurrent.Semaphore; public class BankService { public static void main(String[] args) { Runnable customer = new Runnable() { final Semaphore availableWindow = new Semaphore(5, true); int count = 1; @Override public void run() { int time = (int) (Math.random() * 10 + 3); int num = count++; try { availableWindow.acquire(); System.out.println("正在为第【" + num + "】个客户办理业务,需要时间:" + time + "s!"); Thread.sleep(time * 1000); if (availableWindow.hasQueuedThreads()) { System.out.println("第【" + num + "】个客户已办理完业务,有请下一位!"); } else { System.out.println("第【" + num + "】个客户已办理完业务,没有客户了,休息中!"); } availableWindow.release(); } catch (InterruptedException e) { e.printStackTrace(); } } }; for (int i = 1; i < 10; i++) { new Thread(customer).start(); } } }
4、运行结果
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍Java并发编程Semaphore计数信号量详解,包括了Java并发编程Semaphore计数信号量详解的使用技巧和注意事项,需要的朋友参考一下 Semaphore 是一个计数信号量,它的本质是一个共享锁。信号量维护了一个信号量许可集。线程可以通过调用acquire()来获取信号量的许可;当信号量中有可用的许可时,线程能获取该许可;否则线程必须等待,直到有可用的许可为止。 线程可以通
本文向大家介绍JAVA 多线程之信号量(Semaphore)实例详解,包括了JAVA 多线程之信号量(Semaphore)实例详解的使用技巧和注意事项,需要的朋友参考一下 java Semaphore 简介 信号量(Semaphore),有时被称为信号灯,是在多线程环境下使用的一种设施, 它负责协调各个线程, 以保证它们能够正确、合理的使用公共资源。 一个计数信号量
本文向大家介绍详解Java 信号量Semaphore,包括了详解Java 信号量Semaphore的使用技巧和注意事项,需要的朋友参考一下 Semaphore也是一个同步器,和前面两篇说的CountDownLatch和CyclicBarrier不同,这是递增的,初始化的时候可以指定一个值,但是不需要知道需要同步的线程个数,只需要在同步的地方调用acquire方法时指定需要同步的线程个数; 一.
本文向大家介绍Java 信号量Semaphore的实现,包括了Java 信号量Semaphore的实现的使用技巧和注意事项,需要的朋友参考一下 近日于LeetCode看题遇1114 按序打印,获悉一解法使用了Semaphore,顺势研究,记心得于此。 此解视Semaphore为锁,以保证同一时刻单线程的顺序执行。在此原题上,我作出如下更改。 10个线程的常量池中,分别调用R1,R2,R3的方法多次
本文向大家介绍java并发编程之cas详解,包括了java并发编程之cas详解的使用技巧和注意事项,需要的朋友参考一下 CAS(Compare and swap)比较和替换是设计并发算法时用到的一种技术。简单来说,比较和替换是使用一个期望值和一个变量的当前值进行比较,如果当前变量的值与我们期望的值相等,就使用一个新值替换当前变量的值。这听起来可能有一点复杂但是实际上你理解之后发现很简单,接下来,让
本文向大家介绍python线程信号量semaphore使用解析,包括了python线程信号量semaphore使用解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了python线程信号量semaphore使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.semaphore信号量原理 多线程同时运行,能提高程序的运行效率,但