来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html

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

        }

 }

JDK5.0 特性-线程同步装置之Semaphore的更多相关文章

  1. JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue

    来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...

  2. JDK5.0特性-线程 Callable和Future

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...

  3. JDK5.0 特性-线程锁Lock

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...

  4. JDK5.0 特性-线程 Condition

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291471.html import java.util.concurrent.Executor ...

  5. JDK5.0 特性-线程任务执行架构 ScheduledExecutorService

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html import java.util.concurrent.Callable ...

  6. 线程同步 –Mutex和Semaphore

    上一篇介绍了同步事件EventWaitHandle,以及它的两个子类型AutoResetEvent和ManualResetEvent.下面接着介绍WaitHandle的另外两个子类型Mutex和Sem ...

  7. [b0032] python 归纳 (十七)_线程同步_信号量Semaphore

    代码: # -*- coding: utf-8 -*- """ 多线程并发同步 ,使用信号量threading.Semaphore 逻辑: 多个线程,对同一个共享变量 , ...

  8. JDK5.0 特性 监控与管理虚拟机

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html import java.lang.management.ClassLoa ...

  9. JDK5.0特性,使用ProcessBuilder执行本地命令

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...

随机推荐

  1. Fidder发送Get、POST请求

      Composer:   1.Get请求 a) 请求头加上: Content-Type: application/json; charset=utf-8   b) url:http://localh ...

  2. 通过连接池和字段索引,提升单点登录cas的性能

    cas是多个系统的中心认证,认证的过程就是用户的登录信息和数据库中的信息匹对的过程,假设某一时刻登录的人数非常多,须要频繁的读取数据库,数据库连接的管理就是问题. 前天測试评教时无意之中把单点登录的问 ...

  3. 西部世界第二季全集高清百度云在线观看BT种子迅雷下载

    原名:Westworld地区:美国语言:英语首播:2018-04-23 周一制作公司:HBO类型:科幻/惊悚/悬疑/西部别名:西方极乐园编剧:乔纳森·诺兰 / 丽莎·乔·诺兰导演:乔纳森·诺兰主演:埃 ...

  4. Mysql 区分大小写进行查询

    区分大小写的查询: 因为MySQL的查询是默认不区分大小写的: 如果有些时候需要区分大小写,我们就需要binary这个关键字了. 可以这样用,在stud表中查找sname中带’j’ /’J’: 先不写 ...

  5. JavaScript:Number 对象

    ylbtech-JavaScript:Number 对象 1. Number 对象返回顶部 Number 对象 Number 对象是原始数值的包装对象. 创建 Number 对象的语法: var my ...

  6. 一个简易Asp.net网站日志系统

    前不久在网站上看到了网站日志访问记录组件UserVisitLogsHelp开源了! 这篇博客感觉还不错,就把源码download了下来,学习一下,发现里面的代码书写和设计并不是很好,于是自己改了改.自 ...

  7. Maven WEB 项目使用ProGuard进行混淆,最佳解决方案

    Maven WEB 项目使用ProGuard进行混淆,最佳解决方案 近期公司的Android项目做了混淆,虽说对于保护代码并不是100%的,但混淆后的代码可以使那些不法份子难以阅读,这样也能对代码的保 ...

  8. python3 AttributeError: module 'sklearn' has no attribute 'linear_model'

    以下导入方式报错 import sklearn lr = sklearn.linear_model.LinearRegression() # 需要导入sklearn的linear_model 修改导入 ...

  9. 转 :scikit-learn的GBDT工具进行特征选取。

    http://blog.csdn.net/w5310335/article/details/48972587 使用GBDT选取特征 2015-03-31 本文介绍如何使用scikit-learn的GB ...

  10. 程序员训练机器学习 SVM算法分享

    http://www.csdn.net/article/2012-12-28/2813275-Support-Vector-Machine 摘要:支持向量机(SVM)已经成为一种非常受欢迎的算法.本文 ...