`

多线程之Semaphore

 
阅读更多
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
0
0
分享到:
评论

相关推荐

    Delphi多线程之Semaphore_(信号对象).pdf

    Delphi 多线程之 Semaphore (信号对象) Delphi 多线程中,Semaphore (信号对象) 是一种高效的同步方法,用于控制多线程之间的访问顺序。Semaphore 可以同时处理多个线程,避免了线程之间的冲突和阻塞。 Semaphore ...

    C#多线程之Semaphore用法详解

    Semaphore在多线程编程中有多种应用场景,比如限制对数据库连接池的并发访问,控制并发的网络请求,或者管理系统资源如文件句柄等。使用Semaphore可以有效地避免资源过度消耗,防止系统过载,同时确保任务的有序执行...

    semaphore控制多线程循序执行

    本示例中,我们将深入探讨如何使用Semaphore来控制多线程的循序执行。 Semaphore是一种计数信号量,它可以有正整数值,用于管理多个线程对公共资源的访问。当信号量的值为正时,线程可以获取一个许可(或称资源),...

    多线程(C++)同步Semaphore

    多线程(C++)同步Semaphore

    Linux下多线程编程-Pthread与Semaphore的使用.doc

    Linux 下多线程编程-Pthread 与 Semaphore 的使用 Linux 下的多线程编程是通过使用 POSIX 线程接口,称为 pthread 实现的。要编写 Linux 下的多线程程序,需要使用头文件 pthread.h,连接时需要使用库 libpthread.a...

    Java多线程Semaphore工具的使用详解.rar

    Java多线程编程是开发高并发应用的关键技术之一,Semaphore工具是Java并发包(java.util.concurrent)中的一个重要组件,用于控制同时访问特定资源的线程数量。本篇将深入讲解Semaphore的基本概念、工作原理以及如何...

    java线程并发semaphore类示例

    在Java多线程编程中,线程的并发控制是非常关键的一部分,它确保多个线程能够协同工作并有效地访问共享资源。Java 5.0引入了四个新的同步工具类,它们是Semaphore、CountDownLatch、CyclicBarrier和Exchanger,用于...

    C#语言Semaphore类用法实例(多线程多端口使用端口控制)

    在这个实例中,我们关注的是如何利用Semaphore来管理多线程对多个端口的访问,确保不会出现冲突。Semaphore类可以看作是一个计数器,它维护着一个固定数量的许可证。当一个线程请求一个许可证并获得它时,计数器减一...

    多线程测试(是多线程的测试,对学习多线程的朋友有用)

    在编程领域,多线程是一种常见的技术,它允许程序同时执行多个任务,从而提高系统效率和响应速度。尤其是在处理大量数据、并发操作或者需要进行IO等待时,多线程显得尤为重要。C#作为.NET框架的一部分,提供了丰富的...

    C#多线程互斥实例 多线程获取同一变量

    在实际的多线程应用中,除了`lock`,还可以使用`Monitor`、`Mutex`、`Semaphore`等其他同步机制来实现互斥和资源限制。例如,`Mutex`允许跨进程的互斥访问,而`Semaphore`则可以控制同时访问资源的线程数量。 测试...

    C#.NET多线程实例6个(包括多线程基本使用,多线程互斥等全部多线程使用实例),可直接运行

    在.NET框架中,C#语言提供了强大的多线程支持,使得开发者可以充分利用现代多核处理器的优势,实现并行处理和高效能编程。本资源包含六个C#.NET多线程的实例,涵盖了多线程的基本使用到更高级的概念,如线程互斥。...

    稳定、方便、实用的VB6多线程技术(附老马的ActiveX多线程示例)

    多线程技术是现代软件开发中的重要概念,它允许程序同时执行多个任务,从而提高效率和响应性。VB6虽然相对老旧,但其支持的多线程功能依然具有实用性,尤其是在处理耗时操作或需要并发执行任务的应用场景。 VB6中的...

    多线程编程示例

    在IT领域,多线程编程是一项关键技能,尤其是在性能优化和并发处理方面。本文将深入探讨多线程编程的基础知识,以帮助初学者快速入门。 首先,我们需要理解什么是多线程。多线程是指在一个进程中同时执行多个独立的...

    PB多线程实现

    1. **线程安全**:确保共享数据在多线程环境下正确访问,通常需要使用锁(如Monitor或Mutex)、信号量(Semaphore)或原子操作来实现。 2. **线程间通信**:线程间的同步和通信至关重要,可以使用事件(Event)、...

    C#多线程读写sqlite

    在C#编程中,多线程技术常用于提高应用程序的执行效率,特别是在处理数据库操作时。SQLite是一款轻量级、嵌入式的关系型数据库,它广泛应用于桌面应用、移动设备和Web开发。当多线程环境对SQLite进行读写操作时,...

    .NET多线程实例

    .NET框架的多线程技术是开发高性能应用程序的关键组成部分,特别是在处理并发操作、并行计算以及UI更新时。在.NET 2.0版本中,多线程功能已经得到了充分的优化和增强,允许开发者构建出更加高效的应用程序。下面将...

    易语言多线程访问网页源码,多线程访问网页,子程序_访问网页(1).zip

    在IT行业中,多线程编程是一项关键技能,尤其是在开发高效能的应用程序时。"易语言多线程访问网页源码" 提供了一种利用多线程技术来并发地访问网络资源的方法,这对于需要大量网络请求的项目来说尤其有用。易语言是...

    Delphi多线程详解_delphi_delphi多线程_多线程_

    在编程领域,多线程是一种常见且强大的技术,它允许应用程序同时执行多个任务,从而提高程序的效率和响应性。Delphi,作为一个流行的Object Pascal开发环境,提供了丰富的工具和库来支持多线程编程。本篇文章将深入...

Global site tag (gtag.js) - Google Analytics