java5线程并发库学习之Semaphore

Semaphore的作用类似Lock的功能,不同的是Semaphore的构造函数中可以传入一个int型的参数,用来确定创建一个多大的通道。


Lock一次只允许一个线程进入,解锁后才允许别的线程进入。而Semaphore可以允许多个线程同时进入,一旦有线程释放就会空出一个位置让另外的线程进入。


相当与Lock是一个单车道,而Semaphore是一个多车道。

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

public class SemaphoreTest {

    public static void main(String[] args) {
        ExecutorService es = Executors.newCachedThreadPool();
        final Semaphore sema = new Semaphore(3, true); //表示按排队的先后顺序进入
        for (int i = 0; i < 10; i++) {
            es.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        sema.acquire();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("线程" + Thread.currentThread().getName() + "已进入,当前有"
                            + (3 - sema.availablePermits()) + "个线程并发");
                    try {
                        Thread.sleep(new Random().nextInt(5000));
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("线程" + Thread.currentThread().getName() + "即将离开");
                    sema.release(); //一个线程释放就会允许另外的线程进入
                }
            });
        }
        es.shutdown();
    }
}



结果:

线程pool-1-thread-2已进入,当前有1个线程并发
线程pool-1-thread-1已进入,当前有2个线程并发
线程pool-1-thread-3已进入,当前有3个线程并发
线程pool-1-thread-2即将离开
线程pool-1-thread-5已进入,当前有3个线程并发
线程pool-1-thread-3即将离开
线程pool-1-thread-4已进入,当前有3个线程并发
线程pool-1-thread-1即将离开
线程pool-1-thread-6已进入,当前有3个线程并发
线程pool-1-thread-5即将离开
线程pool-1-thread-8已进入,当前有3个线程并发
线程pool-1-thread-4即将离开
线程pool-1-thread-7已进入,当前有3个线程并发
线程pool-1-thread-7即将离开
线程pool-1-thread-10已进入,当前有3个线程并发
线程pool-1-thread-6即将离开
线程pool-1-thread-9已进入,当前有3个线程并发
线程pool-1-thread-8即将离开
线程pool-1-thread-9即将离开
线程pool-1-thread-10即将离开

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值