先Mark下这篇文章
http://www.cnblogs.com/whgw/archive/2011/09/29/2195555.html
Semaphore 信号量
这是java中控制多线程对某一个资源同时访问的次数的强有力的一个工具
,比如去网吧上网,网吧的座位数是固定的。比如500个。这个500代表同时只能有500个线程来访问网吧资源。只有一个线程释放资源,另一个人(线程)才能进来访问。
试想当semaphore为1的时候,就是说一个资源只能被一个线程访问,这个效果就相当于synchronized 和 ReentrantLock 的作用了。变成了互斥锁同步机制
这里,有个问题, 这样对一个网吧资源的限制性访问,是不是有点像 Executors.newFixxedThreadPool(int n);的方式
public static ExecutorService newFixedThreadPool(int nThreads) {
return new ThreadPoolExecutor(nThreads, nThreads,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
}
固定线程池,最后一个阻塞队列new LinkedBlockingQueue<Runnable> 是一个无界队列。
多出来没线程执行的任务会放到这个阻塞队列中。