信号量限制
操作系统的信号量是个很重要的概念,在进程控制方面都有应用。比如在Windos下可以设置共享文件的最大客户端访问个数。
java.util.concurrent.Semaphore维护了当前访问自身的线程个数。提供同步机制,控制同时访问的线程个数。
Semaphore类的构造方法要求传入给定的许可数。
Semaphore类提供以下方法,控制同时运行的线程数。
voidacquire()
从此信号量获取一个许可,在提供一个许可前一直将线程阻塞,否则线程被中断
voidrelease()
释放一个许可,将其返回给信号量。
下面代码演示在缓存线程池中创建10个线程,由于信号量的限制,只能有3个线程同时运行。
代码如下:【TestSemaphore】
/** * TestSemaphore.java * 版权所有(C) 2011 cuiran2001@163.com * 创建:崔冉 2011-1-14 下午04:22:39 */ package com.cayden.thread835; import java.util.Date; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Semaphore; /** * @author 崔冉 * @version 1.0.0 * @desc */ public class TestSemaphore { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub ExecutorService exec=Executors.newCachedThreadPool(); final Semaphore semp=new Semaphore(3); for(int i=0;i<10;i++){ Runnable run=new Runnable() { public void run(){ try{ //获取许可 semp.acquire(); System.out.println(new Date()+"当前运行的线程是: "+Thread.currentThread().getName()); Thread.sleep((long)(Math.random()*10000)); //释放许可 semp.release(); }catch (InterruptedException e) { // TODO: handle exception } } }; exec.execute(run); } exec.shutdown(); } }
运行结果如下:
Thu Jan 20 14:59:06 CST 2011当前运行的线程是: pool-1-thread-1 Thu Jan 20 14:59:06 CST 2011当前运行的线程是: pool-1-thread-4 Thu Jan 20 14:59:06 CST 2011当前运行的线程是: pool-1-thread-2 Thu Jan 20 14:59:08 CST 2011当前运行的线程是: pool-1-thread-6 Thu Jan 20 14:59:08 CST 2011当前运行的线程是: pool-1-thread-8 Thu Jan 20 14:59:09 CST 2011当前运行的线程是: pool-1-thread-10 Thu Jan 20 14:59:11 CST 2011当前运行的线程是: pool-1-thread-3 Thu Jan 20 14:59:13 CST 2011当前运行的线程是: pool-1-thread-5 Thu Jan 20 14:59:17 CST 2011当前运行的线程是: pool-1-thread-7 Thu Jan 20 14:59:19 CST 2011当前运行的线程是: pool-1-thread-9