您的位置:首页 > 编程语言 > Java开发

Semaphore 信号灯 java示例

2012-01-27 18:07 267 查看
1、Semaphore可以维护当前访问自身的线程个数,并提供了同步机制。使用Semaphore可以控制同时访问资源的线程个数,例如,实现一个文件允许的并发访问数。

Semaphore实现的功能就类似厕所有5个坑,假如有十个人要上厕所,那么同时能有多少个人去上厕所呢?同时只能有5个人能够占用,当5个人中的任何一个人让开后,其中在等待的另外5个人中又有一个可以占用了。

另外等待的5个人中可以是随机获得优先机会,也可以是按照先来后到的顺序获得机会,这取决于构造Semaphore对象时传入的参数选项。

2、单个信号量的Semaphore对象可以实现互斥锁的功能,并且可以是由一个线程获得了“锁”,再由另一个线程释放“锁”,这可应用于死锁恢复的一些场合。

示例如下:

public class SemaphoreTest {

public static void main(String[] args) {

ExecutorService service = Executors.newCachedThreadPool();

final Semaphore sp = new Semaphore(3);

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

Runnable runnable = new Runnable(){

public void run(){

try {

sp.acquire();//获取信号灯

} catch (InterruptedException e1) {

e1.printStackTrace();

}

System.out.println("线程" + Thread.currentThread().getName() +

"进入,当前已有" + (3-sp.availablePermits()) + "个并发");

try {

Thread.sleep((long)(Math.random()*10000));

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("线程" + Thread.currentThread().getName() +

"即将离开");

sp.release();
//释放信号灯

//下面代码有时候执行不准确,因为其没有和上面的代码合成原子单元

System.out.println("线程" + Thread.currentThread().getName() +

"已离开,当前已有" + (3-sp.availablePermits()) + "个并发");

}

};

service.execute(runnable);

}
service.shutdown();

}

}

运行结果:(参考,每次运行的可能不一样)

线程pool-1-thread-1进入,当前已有1个并发

线程pool-1-thread-3进入,当前已有2个并发

线程pool-1-thread-2进入,当前已有3个并发

线程pool-1-thread-3即将离开

线程pool-1-thread-5进入,当前已有3个并发

线程pool-1-thread-3已离开,当前已有3个并发

线程pool-1-thread-2即将离开

线程pool-1-thread-2已离开,当前已有2个并发

线程pool-1-thread-4进入,当前已有3个并发

线程pool-1-thread-1即将离开

线程pool-1-thread-1已离开,当前已有2个并发

线程pool-1-thread-7进入,当前已有3个并发

线程pool-1-thread-5即将离开

线程pool-1-thread-5已离开,当前已有2个并发

线程pool-1-thread-9进入,当前已有3个并发

线程pool-1-thread-4即将离开

线程pool-1-thread-4已离开,当前已有2个并发

线程pool-1-thread-6进入,当前已有3个并发

线程pool-1-thread-7即将离开

线程pool-1-thread-7已离开,当前已有2个并发

线程pool-1-thread-8进入,当前已有3个并发

线程pool-1-thread-6即将离开

线程pool-1-thread-6已离开,当前已有2个并发

线程pool-1-thread-10进入,当前已有3个并发

线程pool-1-thread-10即将离开

线程pool-1-thread-10已离开,当前已有2个并发

线程pool-1-thread-8即将离开

线程pool-1-thread-8已离开,当前已有1个并发

线程pool-1-thread-9即将离开

线程pool-1-thread-9已离开,当前已有0个并发
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: