浅谈Semaphore


一、Semaphore是什么?主要作用是什么?

Semaphore简称信号量,它是JUC包下面对限流提供的一种解决方案。也就是说使用它后,可以保证在同一时间内只能有规定数量的任务可以执行,其它任务进入等待状态。

二、Semaphore的实现原理是什么?

Semaphore的阻塞原理和ReentrantLock的阻塞原理类似,主要区别的地方有两点:

  • 1、Semaphore的state属性的值表示可以有多少个任务可以同时执行,所以该值是可以大于1的,比如state=5表明有五个任务可以同时执行。当有任务执行时state会减一,直至state减为-1表明信号通道已用完,其它任务进入双向链表(同步阻塞队列);
  • 2、Semaphore在释放锁并执行唤醒方法时会持续的进行唤醒(释放锁state加一、唤醒的线程获取锁时state减一),直至state的值为负一为止,也就是说Semaphore的唤醒会不断的往链表后方唤醒线程,直到唤醒的线程无法获取锁为止;

三、Semaphore的简单使用

/**
 * 使用信号量限流
 */
static Semaphore semaphore = new Semaphore(5);

for (int i = 0; i < 10; i++) {
    
    
    Thread thread = new Thread(() -> {
    
    
        try {
    
    
            semaphore.acquire();
            System.out.println(Thread.currentThread().getName() + "正在执行任务。。。");
            Thread.sleep(1000);
            System.out.println(Thread.currentThread().getName() + "任务执行完毕!!!");
        } catch (InterruptedException e) {
    
    
            e.printStackTrace();
        } finally {
    
    
            semaphore.release();
        }
    });
    thread.start();
}

猜你喜欢

转载自blog.csdn.net/qq_42697271/article/details/121532496