信号量Semaphore

信号量Semaphore

Java的信号量实际上是一个功能完备的计数器,能监控有多少数目的线程等待获取资源,并且通过信号量可以得知可用资源的数目等,这里强调数目二字,但不能指出来有哪些在等待,哪些资源可用
作用:用来控制对有限资源的访问数量。
应用场景:有限资源的使用限制

  • public Semaphore(int permits) permits表示初始可用的资源,注意,只是初始值为permits,并不是资源的最大数,通过释放资源的操作可以使可用资源数量超过初始值* * public Semaphore(int permits, boolean fair) fair等待资源的线程是否采用公平策略获取锁,true即是先来先得。(公平锁)
  • acquire()申请资源,当申请的资源>现有可用资源时,申请资源的线程将被阻塞,直到有可用资源或者申请线程被打断,若线程被打断,则抛出InterruptedException异常
  • release()释放一个资源
public class Test1 {
public static void main(String[] args) throws Exception {		
Random r = new Random();// 使用随机整数模拟不定期的出现要上厕所的人		Semaphore wc = new Semaphore(3, true);// 信号量这种编程方式一般用于多个共享资源,但是资源数小于线程数
	for (int i = 1; i <= 6; i++) {		
new Thread(new Person("阿" + i, wc)).start();			                                      Thread.sleep(r.nextInt(100));	
}	
    }
	}
class Person implements Runnable {
private String name;	
private Semaphore sp;	
public Person(String name, Semaphore sp) {	
	  this.name = name;	
	   this.sp = sp;	
	   }
 public void run() {		
 System.out.println(name + ":憋死老子了!");// 查看是否有空闲资源		     if (sp.availablePermits() > 0) {			
 System.out.println("天助我也,有坑位!");		
 } else {			
 System.out.println("卧槽,没坑位了,等会吧....");		
 }
 // 没有资源则需要阻塞当前线程,等待别的线程释放资源
 try {		
 	sp.acquire();// 申请坑位,如果有资源则直接使用,否则阻塞等待-AQS	
 	} catch (Exception e) {			
 	e.printStackTrace();		
 	}
 	// 模拟上厕所的过程----具体使用资源进行业务逻辑处理
 	System.out.println(name + ":终于轮到我了,拉屎就是爽!");
 	try {			
 	Thread.sleep(new Random().nextInt(1000));// 模拟上厕所间		
 	} catch (InterruptedException e) {
 	e.printStackTrace();		
 	}		
 	System.out.println(name + ":拉完了,好臭!");
 	// 释放资源		
 	sp.release();	
 	}
 	 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值