首页 > 代码库 > Java多线程与并发库高级应用之信号量Semaphore
Java多线程与并发库高级应用之信号量Semaphore
JDK1.5提供了一个计数信号量Semaphore类。Semaphore 通常用于限制可以访问某些资源(物理或逻辑的)的线程数目,并提供了同步机制。
Semaphore提供了两个构造器来创建对象:
1)Semaphore(int permits):创建具有给定的许可数和非公平的公平设置的Semaphore。
2)Semaphore(int permits, boolean fair):创建具有给定的许可数和给定的公平设置的Semaphore。如果此信号量保证在争用时按先进先出的顺序授予许可,则为true,否则为false。
如果线程要运行首先要获取信号量,调用信号量的acquire()方法。当某线程执行完后要释放信号量,调用信号量的release()方法。
实现一个同时只允许3个线程并发访问的程序。
[java] view plaincopy
- public class SemaphoreDemo {
- public static void main(String[] args) {
- //定义一个信号数为3的信号量
- final Semaphore semaphore = new Semaphore(3);
- //线程池
- ExecutorService pool = Executors.newCachedThreadPool();
- //创建10个线程
- for(int i = 0; i < 10; i++){
- Runnable target = new Runnable(){
- @Override
- public void run() {
- try {
- //获取信号量
- semaphore.acquire();
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- System.out.println("线程-" + Thread.currentThread().getName() +
- "-已进入,当前已有" + (3-semaphore.availablePermits()) + "个线程并发");
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- System.out.println("线程-" + Thread.currentThread().getName() +
- "-准备离开,当前已有" + (3-semaphore.availablePermits()) + "个线程并发");
- //释放信号量
- semaphore.release();
- System.out.println("线程-" + Thread.currentThread().getName() +
- "-离开,当前已有" + (3-semaphore.availablePermits()) + "个线程并发");
- }
- };
- pool.execute(target);
- }
- pool.shutdown();
- }
- }
运行程序,看到同时只有3个线程并发执行。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。