Semaphore

Semaphone是一个信号量,它控制的是线程并发的数量,必须由获取它的线程释放。常用于限制可以访问某些资源的线程数量,例如通过 Semaphore 限流。看到这里的话,如果不是很理解前面这段话是什么意思,可以先去看看案例代码展示部分,看完后再回头来看看这句话就会有一个新的比较清晰的认识。

Semaphone只有3个操作:

1.初始化

Semaphore semaphore = new Semaphore(3);

2.增加

//释放许可
semaphore.release();

3.减少

//获取许可
semaphore.acquire()

 

案例代码展示:

package com.bc.test;

import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;

public class SemaphoreDemo {

    public static void main(String[] args){
        ExecutorService executorService=Executors.newCachedThreadPool();

        //信号量,只允许3个线程同时访问
        final Semaphore semaphore=new Semaphore(3);

        for(int i=0;i<10;i++){
            final long num=i;
            executorService.submit(new Runnable() {
                public void run() {
                    try{
                        //获取许可
                        semaphore.acquire();
                        //执行
                        System.out.println("Accessing:"+num);
                        Thread.sleep(new Random().nextInt(5000));//模拟随机执行时长
                        //释放
                        semaphore.release();
                        System.out.println("Release..."+num);
                    }catch (Exception e){
                        e.printStackTrace();
                    }
                }
            });
        }
        executorService.shutdown();
    }
}

执行结果如下:

Semaphore_第1张图片

结果解释:此处我们先使用了for循环,提交了10个任务到线程池中,线程池中此时具有10个线程。首先是线程池中的线程0、2、1获取到了信号量,其它的线程此时处于阻塞状态。接着线程2释放了信号量,线程3获取到了信号量,此时拥有信号量的线程为0、1、3,那么接下来可能会释放信号量的只能是这三个线程(线程0、1、3)中的某一个线程,从打印结果可以看出在线程3获取到了信号量后,线程1释放了信号量。依次类推,最多允许3个线程同时获得信号量去执行业务逻辑。

你可能感兴趣的:(并发编程)