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,CyclicBarrier和Exchanger

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

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

 */

/**

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

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

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

 *3.Semaphore的release方法释放了资源池.

 */

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();

       }

}

 

 

 

 

时间: 2024-10-23 01:27:53

JDK5.0新特性系列---11.5.1线程 同步装置之Semaphore的相关文章

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

    import java.util.concurrent.CountDownLatch;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors; /** * CountDownLatch维护一个计数器,等待这个CountDownLatch的线程必须等到计数器为0时才可以继续. * 以下实例模拟服务器的启动,假设启动一个服务器需要初始化3个组件,当3个组件初始化完毕后,服务器才算成功启

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

/**  * Exchanger让两个线程互换信息  * 实例模拟服务生和顾客,服务生往空杯子中倒水,顾客从装满水的杯子中喝水,然后互换杯子,服务生接着倒水,顾客接着喝水.  */ /**  * 使用Exchanger的关键技术点如下:  * 1.初始化Exchanger对象时,可以通过泛型指定杯子能交换的信息类型.如"new Exchanger<String>;"表示只能交换String类型的信息  * 2.Exchanger的exchange方法表示当前线程准备交换信息

JDK5.0新特性系列---11.6线程 BlockingQueue

  importjava.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;   /**     本例介绍一个特殊的队列:BlockingQueue,如果BlockQueue是空的,从BlockingQueue取东西的操作将会

JDK5.0新特性系列---11.3线程 锁Lock

  import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.Reent

JDK5.0新特性系列---11.1线程 Callable和Future

  import java.util.concurrent.Callable; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future;   /**     从本节开始,主要介绍J2SE5.0与线程相关的新特性,新的线程类主要集中在java.util.concurrent 包中,本节实例将介绍如何使用java.uti

JDK5.0新特性系列---11.2线程 任务执行架构

  import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; import java.util.concurrent.ScheduledExecu

JDK5.0新特性系列---11.4线程 Condition

  import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock;   /**  *有时候线程取得lock后需要在一定条件下才能

JDK5.0新特性系列---目录

  JDK5.0新特性系列---目录   JDK5.0新特性系列---1.自动装箱和拆箱   JDK5.0新特性系列---2.新的for循环 JDK5.0新特性系列---3.枚举类型 JDK5.0新特性系列---4.静态导入 JDK5.0新特性系列---5.可变长参数Varargs JDK5.0新特性系列---6.格式化输出 JDK5.0新特性系列---7.使用ProcessBuilder执行本地命令 JDK5.0新特性系列---8.泛型编程 JDK5.0新特性系列---9.注释功能Annota

JDK5.0新特性系列---10.监控与管理虚拟机

  import java.lang.management.ClassLoadingMXBean; import java.lang.management.CompilationMXBean; import java.lang.management.GarbageCollectorMXBean; import java.lang.management.ManagementFactory; import java.lang.management.MemoryMXBean; import java.