14.Java5的Semaphere同步工具

 1 import java.util.concurrent.ExecutorService;
 2 import java.util.concurrent.Executors;
 3 import java.util.concurrent.Semaphore;
 4 
 5 /**
 6  * 14.Java5的Semaphere同步工具
 7  *         Semaphore可以维护当前访问自身的线程个数,并提供了同步机制。
 8  * 使用Semaphore可以控制同时访问资源的线程个数,例如,实现一个
 9  * 文件允许的并发访问数。
10  *         单个信号量的Semaphore对象可以实现互斥锁的功能,并且可以是由
11  * 一个线程获得了“锁”,再由另一个线程释放“锁”,这可应用于死锁恢复的一些场合。
12  * @author LiTaiQing
13  *
14  */
15 public class SemaphoreTest {
16     public static void main(String[] args) {
17         ExecutorService service = Executors.newCachedThreadPool();
18         final Semaphore sp = new Semaphore(3);
19         for (int i = 0; i < 10; i++) {
20             Runnable runnable = new Runnable() {
21                 public void run() {
22                     try {
23                         sp.acquire();
24                     } catch (InterruptedException e1) {
25                         e1.printStackTrace();
26                     }
27                     System.out.println("线程" + Thread.currentThread().getName()
28                             + "进入,当前已有" + (3 - sp.availablePermits()) + "个并发");
29                     try {
30                         Thread.sleep((long) (Math.random() * 10000));
31                     } catch (InterruptedException e) {
32                         e.printStackTrace();
33                     }
34                     System.out.println("线程" + Thread.currentThread().getName()
35                             + "即将离开");
36                     sp.release();
37                     // 下面代码有时候执行不准确,因为其没有和上面的代码合成原子单元
38                     System.out.println("线程" + Thread.currentThread().getName()
39                             + "已离开,当前已有" + (3 - sp.availablePermits()) + "个并发");
40                 }
41             };
42             service.execute(runnable);
43         }
44     }
45 }
原文地址:https://www.cnblogs.com/litaiqing/p/4650953.html