一、Semaphore介绍
①、Semaphore是一种在多线程环境下使用的设施,该设施负责协调各个线程,以保证它们能够正确、合理的使用公共资源的设施,也是操作系统中用于控制进程同步互斥的量。
②、Semaphore分为单值和多值两种,前者只能被一个线程获得,后者可以被若干个线程获得。
③、Semaphore是并发包中提供的用于控制某资源同时被访问的个数
④、操作系统的信号量是个很重要的概念,在进程控制方面都有应用。Java 并发库 的⑤、Semaphore 可以很轻松完成信号量控制,Semaphore可以控制某个资源可被同时访问的个数,通过 acquire() 获取一个许可,如果没有就等待,而 release() 释放一个许可。
⑥、Semaphore维护了当前访问的个数,提供同步机制,控制同时访问的个数
⑦、Semaphore类只是一个资源数量的抽象表示,并不负责管理资源对象本身,可能有多个线程同时获取到资源使用许可,因此需要使用同步机制避免数据竞争。
二、Semaphore中的acquire()与release()方法( 包含acquire(int permits)和release(int permits) )代码示例
package chapter3.semaphore;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;
/**
* @author czd
*/
public class SemaphoreTest {
public static void main(String[] args) {
/**
* 3代表同一时间允许的最大线程数量
* 当为1时,Semaphore的作用相当于一个Lock
*/
final Semaphore semaphore = new Semaphore(3);
for (int i = 0; i < 5; i++){
new Thread(){
@Override
public void run() {
try {
//从此信号量获取一个许可,在提供一个许可前一直将线程阻塞,否则线程被中断。
semaphore.acquire();
//从此信号量获取给定数目的许可,在提供这些许可前一直将线程阻塞,或者线程已被中断。
// semaphore.acquire(3);
System.out.println(Thread.currentThread().getName() + "获取信号量");
TimeUnit.SECONDS.sleep(2);
}catch (Exception e){
e.printStackTrace();
}finally {
/**
* 释放给定数目的许可,将其返回到信号量。
* 注意有release和无realse的区别
*/
semaphore.release();
//对应上面semaphore.acquire(3);,允许多少个就得释放多少个
// semaphore.release(3);
}
System.out.println(Thread.currentThread().getName() + "出去");
}
}.start();
}
}
}
输出结果
由于Semaphore中的方法太多,这里就不一一介绍,只是简单讲一下两个比较重要的方法,如果想要了解更多Semaphore的更多的方法,可以去http://tool.oschina.net/apidocs/apidoc?api=jdk-zh中查找Semaphore,那里有详细的Semaphore的所有方法。