Semaphore(信号量)同步器的使用主要是完成Java多线程并发。Semaphore类是定义于concurrent工具包下的对java.io.Serializable接口的一个实现类。主要是通过Semaphore构造方法对信号量进行初始化,原型如下:
public Semaphore(int permits) {
sync = new NonfairSync(permits);
}
参数permits是初始化信号量的数目,也就是最多同时允许并发线程的数目。定义的semaphore对象常用的两种方法acquire和release定义如下:
public void acquire() throws InterruptedException {
sync.acquireSharedInterruptibly(1);
}
public void release() {
sync.releaseShared(1);
}
acquire是子线程获取信号量,而release是子线程完成任务后进行信号量的释放。semaphore同步器的原理其实很简单,获取信号量的线程进行运行,并发的线程数目由初始化的信号量决定,运行完的子线程释放信号量,其它挂起的线程会获取到释放的信号量进行运行。如下所示:
package concurrent;
import java.util.concurrent.Semaphore;
public class TestSemaphore {
public static void main(String[] args) {
'''初始化信号量的数目''
Semaphore semaphore = new Semaphore(2);
Service service1