package com.test4;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;
/**
* 信号量
*
* @author 林计钦
* @version 1.0 2013-7-25 下午02:03:40
*/
public class SemaphoreTest {
public static void main(String[] args) {
// 线程池
ExecutorService exec = Executors.newCachedThreadPool();
// 只能5个线程同时访问
final Semaphore semp = new Semaphore(5);
// 模拟20个客户端访问
for (int index = 1; index <= 20; index++) {
final int NO = index;
Runnable run = new Runnable() {
public void run() {
try {
// 获取许可 如果当前许可证拿不到 ,此方法会一直阻塞等待 知道有可用的许可证
semp.acquire();
System.out.println("Accessing: " + NO);
Thread.sleep((long) (Math.random() * 10000));
// 访问完后,释放
semp.release();
//availablePermits()指的是当前信号灯库中有多少个可以被使用
System.out.println("getQueueLength:"+semp.getQueueLength()+"------------availablePermits:" + semp.availablePermits()+"--------drainPermits:"+semp.drainPermits());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
exec.execute(run);
}
// 退出线程池
exec.shutdown();
}
}
运行结果:
Accessing: 1
Accessing: 2
Accessing: 3
Accessing: 4
Accessing: 5
Accessing: 6
getQueueLength:14------------availablePermits:0--------drainPermits:0
Accessing: 7
getQueueLength:13------------availablePermits:0--------drainPermits:0
getQueueLength:13------------availablePermits:0--------drainPermits:0
Accessing: 10
Accessing: 11
getQueueLength:11------------availablePermits:0--------drainPermits:0
Accessing: 8
getQueueLength:10------------availablePermits:0--------drainPermits:0
Accessing: 12
getQueueLength:9------------availablePermits:0--------drainPermits:0
getQueueLength:9------------availablePermits:0--------drainPermits:0
Accessing: 13
getQueueLength:8------------availablePermits:0--------drainPermits:0
Accessing: 9
getQueueLength:7------------availablePermits:0--------drainPermits:0
Accessing: 14
Accessing: 15
getQueueLength:5------------availablePermits:0--------drainPermits:0
getQueueLength:5------------availablePermits:1--------drainPermits:1
Accessing: 16
getQueueLength:4------------availablePermits:0--------drainPermits:0
getQueueLength:4------------availablePermits:0--------drainPermits:0
Accessing: 17
Accessing: 18
getQueueLength:2------------availablePermits:0--------drainPermits:0
getQueueLength:2------------availablePermits:0--------drainPermits:0
Accessing: 19
Accessing: 20
getQueueLength:0------------availablePermits:0--------drainPermits:0
getQueueLength:0------------availablePermits:1--------drainPermits:1
getQueueLength:0------------availablePermits:1--------drainPermits:1
getQueueLength:0------------availablePermits:1--------drainPermits:1
getQueueLength:0------------availablePermits:1--------drainPermits:1
分享到:
相关推荐
Delphi 多线程之 Semaphore (信号对象) Delphi 多线程中,Semaphore (信号对象) 是一种高效的同步方法,用于控制多线程之间的访问顺序。Semaphore 可以同时处理多个线程,避免了线程之间的冲突和阻塞。 Semaphore ...
主要为大家详细介绍了C#多线程之Semaphore用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
多线程(C++)同步Semaphore
semaphore控制多线程循序执行,网上 找的例子更改的希望对大家有用
Java多线程Semaphore工具的使用详解.rar
Java 5.0里新加了4个协调线程间进程的同步装置,它们分别是Semaphore, CountDownLatch, CyclicBarrier和Exchanger,本例主要介绍Semaphore,Semaphore是用来管理一个资源池的工具,可以看成是个通行证
Linux下多线程编程-Pthread与Semaphore的使用.doc
C#语言Semaphore类用法实例,多线程 用于有多个同类型共享资源(比如端口)时,如何协调端口分配给线程访问资源的问题,是一个简单模拟实例(源代码)。
Semaphore : 用来确保一定资源多线程访问时的上限,例如资源池。 Event : 是最简单的线程间通信的方式,一个线程可以发送信号,其他的线程接收到信号后执行操作。 二、实例 1)Lock & RLock Lock对象的状态可以...
多线程编程:信号量使用。 打包文件包含两个文件:c文件源代码、Makefile文件,运行环境在Ubuntu14.04下,使用自带的gcc编译器,同学们只需将文件夹复制到某一目录下之后在终端执行:1.“make”生成“test”可执行...
主要介绍了python多线程semaphore实现线程数控制的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
JAVA多线程--信号量(Semaphore)_.docx
主要介绍了JAVA 多线程之信号量(Semaphore)实例详解的相关资料,需要的朋友可以参考下
c: 多线程访问同一资源 d: 经典线程同步互斥问题 e: 使用关键段解决子线程互斥问题 f: 利用事件实现线程同步问题 g: 利用互斥量来解决线程同步互斥问题 h: problem1 生产者消费者问题 (1生产者 1消费者 1...
java多线程每个线程挨着打印ABC的4种实现方式,有4个线程t1、t2、t3、t4,t1打印A后t2打印A再t3打印A再t4打印A,然后从新回到t1打印B再t2打印B...t4打印B... 4个线程轮流打印abc... 一个线程可以理解为一个人,打印...
多线程同时运行,能提高程序的运行效率,但是并非线程越多越好,而semaphore信号量可以通过内置计数器来控制同时运行线程的数量,启动线程(消耗信号量)内置计数器会自动减一,线程结束(释放信号量)内置计数器会自动...
自己编写的简单的多线程小程序,一共四个线程,分别执行(+1,-1),(+2,-2),(+3,-3),(+4,-4),用semaphore实现同步。每次输入非零数,等待四个waiting,可以出现以一百为基数的结果。每次结果相同。如果有...
Task不同于SWI之处在于它在执行过程中能被挂起直到必需资源有效,任务之间可以通过queue、semaphore、mailbox进行通信;Background thread(IDL)不运行时才运行。 DSPBIOS多线程技术中有三种函数:CLK function、...