Java 专栏

Java 信号量

2017-08-10  本文已影响30人  _凌浩雨

信号量的使用

Semaphore当前在多线程环境下被扩放使用,操作系统的信号量是个很重要的概念,在进程控制方面都有应用。Java 并发库 的Semaphore 可以很轻松完成信号量控制,Semaphore可以控制某个资源可被同时访问的个数,通过 acquire() 获取一个许可,如果没有就等待,而 release() 释放一个许可。比如在Windows下可以设置共享文件的最大客户端访问个数。

public class Client {
    public static void main(String[] args) {
        // 创建可缓存的线程池
        ExecutorService executorService = Executors.newCachedThreadPool();
        // 创建一个只能5个线程同时访问的信号量
        final Semaphore semaphore = new Semaphore(5);
        // 开启20个线程,相当于模拟20个用户
        for (int i = 0; i < 20; i++) {
            final int num = i;
            Runnable runnable = new Runnable() {
                @Override
                public void run() {
                    try {
                        // 阻塞函数,直到有可访问的线程,才继续运行
                        semaphore.acquire();
                        System.out.println("接受: " +num);
                        // 让线程睡眠一定得时间
                        Thread.sleep((long) (Math.random()*1000));
                        //线程访问结束后释放当前信号量
                        semaphore.release();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            };
            // 线程池执行任务
            executorService.execute(runnable);
        }
        // 立即退出线程池
        executorService.shutdown();
    }
}

运行结果如下:

运行结果

其中在执行semaphore.acquire()方法时,阻塞时间不同,因此前五个数据在打印时顺序不同,但之后每次都只会释放一个接受一个,故此,之后都是按顺序来排列的。

上一篇下一篇

猜你喜欢

热点阅读