java5线程并发库学习之Semaphore
来源:互联网 发布:淘宝卖家后台登陆网址 编辑:程序博客网 时间:2024/05/01 04:45
Semaphore的作用类似Lock的功能,不同的是Semaphore的构造函数中可以传入一个int型的参数,用来确定创建一个多大的通道。
Lock一次只允许一个线程进入,解锁后才允许别的线程进入。而Semaphore可以允许多个线程同时进入,一旦有线程释放就会空出一个位置让另外的线程进入。
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即将离开
0 0
- java5线程并发库学习之Semaphore
- java5线程并发库学习之Semaphore
- 线程并发库之semaphore
- Java5 并发线程学习
- java5线程并发库
- java5 线程并发库
- java--加强之 Java5的线程并发库
- Java基础加强之 Java5的线程并发库
- 多线程并发库高级应用 之 java5中的线程并发库--线程池、Callable&Future
- 多线程并发库高级应用 之 java5中的线程并发库--线程锁技术
- 多线程并发库高级应用 之 java5中的线程并发库--线程池、Callable&Future
- java多线程并发库高级应用 之 java5中的线程并发库--线程池、Callable&Future
- 多线程并发库高级应用 之 java5中的线程并发库--线程锁技术
- 【Java多线程与并发库】8.java5线程并发库之线程池的应用
- 【Java多线程与并发库】8.java5线程并发库之线程池的应用
- java5线程并发库中的工具
- 多线程及java5的线程并发库
- java5线程并发库的应用(九)
- oracle递归遍历查询
- Linux下安装LoadRunner LoadGenerator
- Linux进程间通信--共享内存与信号量
- ConcurrentHashMap原理
- mahout bayes源码分析总结
- java5线程并发库学习之Semaphore
- POJ 2202 哈希
- spring 依赖注入
- java设计模式之观察者模式
- java设计模式之单例模式
- RxJava使用场景小结
- Ag(The Silver Searcher)相关
- 向量范数和矩阵范数
- visio调整画布大小和旋转画布