Semaphore 允许多个线程同时访问

/**
 * 
 * @author beiyaoyao
 */
public class SemaphoreDemo implements Runnable {
    //设置有几个线程可以进入执行的代码段
    final Semaphore semaphore = new Semaphore(5);


    @Override
    public void run() {
        try {
            semaphore.acquire();

            Thread.sleep(5000);

            System.out.println(Thread.currentThread().getId() + "exec");
            //释放信号量,如果不释放导致内存泄漏,那么进入该临界区的线程资源就越来越少
            semaphore.release();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

    }
    public static void main(String[] args) {
        //newFixedThreadPool(10)用工厂生产一个容纳10个线程的线程池
        ExecutorService exec = Executors.newFixedThreadPool(10);

        final SemaphoreDemo demo = new SemaphoreDemo();

        for(int i = 0 ; i < 10 ; i ++){

            exec.submit(demo);

        }
        exec.shutdown();
    }

}

执行完该程序后,首先休眠5秒,结束后会输出5个线程的ID,再休眠5秒,继续输出5个线程的id。输出的线程id,以5个一组为单位。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值