java-Semaphore

7次阅读

共计 1102 个字符,预计需要花费 3 分钟才能阅读完成。

Semaphore 简介

Semaphore 是一种基于计数的信号量。它可以设定一个阈值,基于此,多个线程竞争获取许可信号,做自己的申请后归还,超过阈值后,线程申请许可信号将会被阻塞。Semaphore 可以用来构建一些对象池,资源池之类的,比如数据库连接池,我们也可以创建计数为 1 的 Semaphore,将其作为一种类似互斥锁的机制,这也叫二元信号量,表示两种互斥状态。它的用法如下:
availablePermits 函数用来获取当前可用的资源数量
wc.acquire(); // 申请资源
wc.release();// 释放资源

public Semaphore(int permits,boolean fair)
permits: 初始化可用的许可数目。
fair: 若该信号量保证在征用时按 FIFO 的顺序授予许可,则为 true,否则为 false;

例子

餐厅 2 个座位,但是有 3 个人要等位就餐

public class SemaphoreThread extends Thread {
    private String name;
    private Semaphore semaphore;

    public SemaphoreThread(String name, Semaphore semaphore) {
        this.name = name;
        this.semaphore = semaphore;
    }

    @Override
    public void run() {if (semaphore.availablePermits() <= 0) {System.out.println(name + "等位中。。。");
        }
        try {semaphore.acquire();
            System.out.println(name + "开始就餐了。。");
            Thread.sleep(new Random().nextInt(1000));
        } catch (InterruptedException e) {e.printStackTrace();
        }
        System.out.println(name + "吃完了。。");
        semaphore.release();}
}

请求:

@RequestMapping("test-semaphore")
    public void testSemaphore() {Semaphore semaphore = new Semaphore(5);
        for (int i = 1; i <= 10; i++) {new SemaphoreThread("第" + i + "个人", semaphore).start();}
    }

结果:
第 1 个人开始就餐了。。
第 2 个人开始就餐了。。
第 3 个人等位中。。。
第 1 个人吃完了。。
第 3 个人开始就餐了。。
第 2 个人吃完了。。
第 3 个人吃完了。。

正文完
 0