Bootstrap

Java并发同步器--Semaphore

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
;