Java多线程——同步器 Semaphore、 CountDownLatch、 CyclicBarrier 、Exchanger

本文详细介绍了Java多线程中的四个同步器:Semaphore用于限制访问资源的线程数量;CountDownLatch是一个倒计数锁存器,常用于线程等待;CyclicBarrier是一个可重置的多路同步点,适用于固定大小线程组的同步;Exchanger则允许两个线程在特定点交换对象,常见于线程间的配对和交换操作。
摘要由CSDN通过智能技术生成

同步器 一般与一组线程对象使用,它维护一个状态,根据它的状态,它让一个线程通过或强迫线程等待。


1.Semaphore是一个经典的并发工具,通常用于限制可以访问某些资源(物理或逻辑的)的线程数目。

class Pool {
   private static final int MAX_AVAILABLE = 100;//许可数
   private final Semaphore available = new Semaphore(MAX_AVAILABLE, true);//创建具有给定的许可数和给定的公平设置的Semaphore。
   public Object getItem() throws InterruptedException {
     available.acquire();//从此信号量获取一个许可,在提供一个许可前一直将线程阻塞,否则线程被中断。
     return getNextAvailableItem();
   }

   public void putItem(Object x) {
     if (markAsUnused(x))
       available.release();//释放一个许可,将其返回给信号量
   }

   // Not a particularly efficient data structure; just for demo

   protected Object[] items = ... whatever kinds of items being managed
   protected boolean[] used = new boolean[MAX_AVAILABLE];

   protected synchronized Object getNextAvailableItem() {//同步锁
     for (int i = 0; i < MAX_AVAILABLE; ++i) {
       if (!used[i]) {
          used[i] = true;
          return items[i];
       }
     }
     return null; // not reached
   }

   protected synchronized boolean markAsUnused(Object item) {
     for (int i = 0; i < MAX_AVAILABLE; ++i) {
       if (item == items[i]) {
          if (used[i]) {
            used[i] = false;
            return true;
          } else
            return false;
       }
     }
     return false;
   }

 }



[1].信号量(控制访问资源的线程数量)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值