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 }