Semaphore在java线程控制中通常被用作资源的限制访问数量,如果我们想让某个资源同时只能有一定数量的线程访问,那么我们就可以使用Semaphore来进行限制了。Semaphore将限制数量概念化成一个维护一组许可证的对象,我们可以通过构造器Semaphore(int permits)来初始化一个Semaphore对象,其中permits指定了许可证的数量。
许可证还存在一个公平策略的问题,因为资源本身被限制访问,当有多个线程在等待访问许可证时,如果采用非公平策略则不保证获取许可证的顺序,如果采用公平策略则按照先来先得的顺序发放许可证。默认情况下,采用的是非公平策略,如果想使用公平策略,需要使用构造器Semaphore(int permits,boolean fair),当我们把fair设置为true时,就采用了公平策略。公平策略能防止线程被饿死,但是非公平策略的处理速度有优势。
Semaphore提供了一系列方法来完成资源的限制访问,详细的方法描述建议大家查看java doc文档,这里面给出几个最为常用的方法介绍:1.acquire方法获取一个许可证,如果没有可用的许可证则会阻塞。2.availablePermits方法返回当前可用许可证的数量。3.release方法释放一个许可证,可用许可证的数量会加1.为了描述Semaphore的应用,我们看一个例子
例子中创建了三个线程来访问一个被限制的资源Number,例子清晰地描述了Semaphore的使用。
参考链接