JDK5.0新特性系列---11.5.1线程 同步装置之Semaphore

简介:

import java.util.ArrayList;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Semaphore;

import java.util.concurrent.locks.Lock;

import java.util.concurrent.locks.ReentrantLock;

/**

*Java 5.0里新增加了4个协调线程间进程的同步装置,它们分别是:Semaphore,CountDownLatch,CyclicBarrierExchanger

*Semaphore可以控制运行线程的个数

*Semaphore是一个用来管理资源池的工具,可以看成是个通行证,线程要想从资源池拿到资源必须先拿到通行证,如果线程暂时拿不到通告证,线程就会被阻断,进入等待状态.

*/

/**

*使用Semaphore的关键技术点如下:

*1.在构造Semaphore对象时,必须提供通行证的数目,"newSemaphore(3)"将创建一个具有3个通行证的Semaphore对象,一旦该对象被创建,其通行证数量是不能改变的.

*2.Semaphoreacquire方法取得一个通行证,如果通行证已经发完了,当前线程将进入等待状态,直到有其他线程释放了通行证.

*3.Semaphorerelease方法释放了资源池.

*/

public class SemaphoreTest {

/**

* 模拟资源池的类

* 只为池发放2个通行证,即同时只允许2个线程获得池中的资源

*/

public static class Pool{

ArrayList<String> pool = null; //保存资源池中的资源

Semaphore pass = null; //通行证

Lock lock = new ReentrantLock();

public Pool(int size){

//初始化资源池

pool = new ArrayList<String>();

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

pool.add("Resource " + i);

}

//发送2个通行证

pass = new Semaphore(2);

}

public String get()throws InterruptedException{

//获取通行证,只有得到通行证后才能得到资源

System.out.println("Try to get a pass...");

pass.acquire();

System.out.println("Got a pass");

return getResource();

}

private String getResource(){

lock.lock();

String result = pool.remove(0);

System.out.println("资源 " + result + "被取走");

lock.unlock();

return result;

}

public void put(String resource){

//归还通行证,并那还资源

System.out.println("Released a pass");

pass.release();

releaseResource(resource);

}

private void releaseResource(String resource){

lock.lock();

System.out.println("资源 " + resource + " 被归还");

pool.add(resource);

lock.unlock();

}

}

public static void testPool(){

//准备10个资源的资源池

final Pool aPool = new Pool(10);

Runnable worker = new Runnable(){

@Override

public void run() {

String resource = null;

try{

resource = aPool.get();//取得resource

//resource做工作

System.out.println("I finished on " + resource);

Thread.sleep(500);

System.out.println("I finished on " + resource);

}catch(InterruptedException ex){

}

aPool.put(resource);

}

};

//启动5个任务

ExecutorService service = Executors.newCachedThreadPool();

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

service.submit(worker);

}

service.shutdown();

}

public static void main(String... args){

SemaphoreTest.testPool();

}

}




本文转自远哥博客园博客,原文链接:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html,如需转载请自行联系原作者

相关文章
|
12月前
|
Java 测试技术 调度
JDK21有没有什么稳定、简单又强势的特性?
这篇文章主要介绍了Java虚拟线程的发展及其在AJDK中的实现和优化。
JDK21有没有什么稳定、简单又强势的特性?
|
算法 NoSQL Java
Springboot3新特性:GraalVM Native Image Support和虚拟线程(从入门到精通)
这篇文章介绍了Spring Boot 3中GraalVM Native Image Support的新特性,提供了将Spring Boot Web项目转换为可执行文件的步骤,并探讨了虚拟线程在Spring Boot中的使用,包括如何配置和启动虚拟线程支持。
1222 9
Springboot3新特性:GraalVM Native Image Support和虚拟线程(从入门到精通)
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
210 7
|
Dubbo Java 应用服务中间件
剖析Tomcat线程池与JDK线程池的区别和联系!
剖析Tomcat线程池与JDK线程池的区别和联系!
566 0
剖析Tomcat线程池与JDK线程池的区别和联系!
|
Java C++
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
178 0
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
191 3
|
监控 数据可视化 Java
使用JDK自带的监控工具JConsole来监控线程池的内存使用情况
使用JDK自带的监控工具JConsole来监控线程池的内存使用情况
|
监控 数据可视化 Java
如何使用JDK自带的监控工具JConsole来监控线程池的内存使用情况?
如何使用JDK自带的监控工具JConsole来监控线程池的内存使用情况?
|
缓存 Java 调度
【Java 并发秘籍】线程池大作战:揭秘 JDK 中的线程池家族!
【8月更文挑战第24天】Java的并发库提供多种线程池以应对不同的多线程编程需求。本文通过实例介绍了四种主要线程池:固定大小线程池、可缓存线程池、单一线程线程池及定时任务线程池。固定大小线程池通过预设线程数管理任务队列;可缓存线程池能根据需要动态调整线程数量;单一线程线程池确保任务顺序执行;定时任务线程池支持周期性或延时任务调度。了解并正确选用这些线程池有助于提高程序效率和资源利用率。
274 2
|
Java API
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作

热门文章

最新文章