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 ...
Semaphore在多线程编程中有多种应用场景,比如限制对数据库连接池的并发访问,控制并发的网络请求,或者管理系统资源如文件句柄等。使用Semaphore可以有效地避免资源过度消耗,防止系统过载,同时确保任务的有序执行...
本示例中,我们将深入探讨如何使用Semaphore来控制多线程的循序执行。 Semaphore是一种计数信号量,它可以有正整数值,用于管理多个线程对公共资源的访问。当信号量的值为正时,线程可以获取一个许可(或称资源),...
多线程(C++)同步Semaphore
Linux 下多线程编程-Pthread 与 Semaphore 的使用 Linux 下的多线程编程是通过使用 POSIX 线程接口,称为 pthread 实现的。要编写 Linux 下的多线程程序,需要使用头文件 pthread.h,连接时需要使用库 libpthread.a...
Java多线程编程是开发高并发应用的关键技术之一,Semaphore工具是Java并发包(java.util.concurrent)中的一个重要组件,用于控制同时访问特定资源的线程数量。本篇将深入讲解Semaphore的基本概念、工作原理以及如何...
在Java多线程编程中,线程的并发控制是非常关键的一部分,它确保多个线程能够协同工作并有效地访问共享资源。Java 5.0引入了四个新的同步工具类,它们是Semaphore、CountDownLatch、CyclicBarrier和Exchanger,用于...
在这个实例中,我们关注的是如何利用Semaphore来管理多线程对多个端口的访问,确保不会出现冲突。Semaphore类可以看作是一个计数器,它维护着一个固定数量的许可证。当一个线程请求一个许可证并获得它时,计数器减一...
"大漠多线程模板"是一个专门针对C#开发的多线程处理框架,它为开发者提供了便捷的方式来管理和优化多线程应用。这个框架由知名开发者"大漠"创建,旨在简化复杂的并发编程,提高代码的可读性和可维护性。 多线程允许...
在编程领域,多线程是一种常见的技术,它允许程序同时执行多个任务,从而提高系统效率和响应速度。尤其是在处理大量数据、并发操作或者需要进行IO等待时,多线程显得尤为重要。C#作为.NET框架的一部分,提供了丰富的...
在实际的多线程应用中,除了`lock`,还可以使用`Monitor`、`Mutex`、`Semaphore`等其他同步机制来实现互斥和资源限制。例如,`Mutex`允许跨进程的互斥访问,而`Semaphore`则可以控制同时访问资源的线程数量。 测试...
在.NET框架中,C#语言提供了强大的多线程支持,使得开发者可以充分利用现代多核处理器的优势,实现并行处理和高效能编程。本资源包含六个C#.NET多线程的实例,涵盖了多线程的基本使用到更高级的概念,如线程互斥。...
多线程技术是现代软件开发中的重要概念,它允许程序同时执行多个任务,从而提高效率和响应性。VB6虽然相对老旧,但其支持的多线程功能依然具有实用性,尤其是在处理耗时操作或需要并发执行任务的应用场景。 VB6中的...
在C#编程中,多线程技术常用于提高应用程序的执行效率,特别是在处理数据库操作时。SQLite是一款轻量级、嵌入式的关系型数据库,它广泛应用于桌面应用、移动设备和Web开发。当多线程环境对SQLite进行读写操作时,...
在IT领域,多线程编程是一项关键技能,尤其是在性能优化和并发处理方面。本文将深入探讨多线程编程的基础知识,以帮助初学者快速入门。 首先,我们需要理解什么是多线程。多线程是指在一个进程中同时执行多个独立的...
1. **线程安全**:确保共享数据在多线程环境下正确访问,通常需要使用锁(如Monitor或Mutex)、信号量(Semaphore)或原子操作来实现。 2. **线程间通信**:线程间的同步和通信至关重要,可以使用事件(Event)、...
.NET框架的多线程技术是开发高性能应用程序的关键组成部分,特别是在处理并发操作、并行计算以及UI更新时。在.NET 2.0版本中,多线程功能已经得到了充分的优化和增强,允许开发者构建出更加高效的应用程序。下面将...
在编程领域,多线程是一种常见且强大的技术,它允许应用程序同时执行多个任务,从而提高程序的效率和响应性。Delphi,作为一个流行的Object Pascal开发环境,提供了丰富的工具和库来支持多线程编程。本篇文章将深入...