All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.gemstone.org.jgroups.oswego.concurrent.SemaphoreControlledChannel Maven / Gradle / Ivy

There is a newer version: 2.0-BETA
Show newest version
/** Notice of modification as required by the LGPL
 *  This file was modified by Gemstone Systems Inc. on
 *  $Date$
 **/
/*
  File: SemaphoreControlledChannel.java

  Originally written by Doug Lea and released into the public domain.
  This may be used for any purposes whatsoever without acknowledgment.
  Thanks for the assistance and support of Sun Microsystems Labs,
  and everyone contributing, testing, and using this code.

  History:
  Date       Who                What
  16Jun1998  dl               Create public version
   5Aug1998  dl               replaced int counters with longs
  08dec2001  dl               reflective constructor now uses longs too.
*/

package com.gemstone.org.jgroups.oswego.concurrent;
import java.lang.reflect.*;

/**
 * Abstract class for channels that use Semaphores to
 * control puts and takes.
 * 

[ Introduction to this package. ] **/ public abstract class SemaphoreControlledChannel implements BoundedChannel { protected final Semaphore putGuard_; protected final Semaphore takeGuard_; protected int capacity_; /** * Create a channel with the given capacity and default * semaphore implementation * @exception IllegalArgumentException if capacity less or equal to zero **/ public SemaphoreControlledChannel(int capacity) throws IllegalArgumentException { if (capacity <= 0) throw new IllegalArgumentException(); capacity_ = capacity; putGuard_ = new Semaphore(capacity); takeGuard_ = new Semaphore(0); } /** * Create a channel with the given capacity and * semaphore implementations instantiated from the supplied class * @exception IllegalArgumentException if capacity less or equal to zero. * @exception NoSuchMethodException If class does not have constructor * that intializes permits * @exception SecurityException if constructor information * not accessible * @exception InstantiationException if semaphore class is abstract * @exception IllegalAccessException if constructor cannot be called * @exception InvocationTargetException if semaphore constructor throws an * exception **/ public SemaphoreControlledChannel(int capacity, Class semaphoreClass) throws IllegalArgumentException, NoSuchMethodException, SecurityException, InstantiationException, IllegalAccessException, InvocationTargetException { if (capacity <= 0) throw new IllegalArgumentException(); capacity_ = capacity; Class[] longarg = { Long.TYPE }; Constructor ctor = semaphoreClass.getDeclaredConstructor(longarg); Object[] cap = { Long.valueOf(capacity) }; putGuard_ = (Semaphore)(ctor.newInstance(/*(Object[]) GemStoneAddition*/cap)); Object[] zero = { Long.valueOf(0) }; takeGuard_ = (Semaphore)(ctor.newInstance(/*(Object[]) GemStoneAddition*/zero)); } public int capacity() { return capacity_; } /** * Return the number of elements in the buffer. * This is only a snapshot value, that may change * immediately after returning. **/ public int size() { return (int)(takeGuard_.permits()); } /** * Internal mechanics of put. **/ protected abstract void insert(Object x); /** * Internal mechanics of take. **/ protected abstract Object extract(); public void put(Object x) throws InterruptedException { if (x == null) throw new IllegalArgumentException(); if (Thread.interrupted()) throw new InterruptedException(); putGuard_.acquire(); try { insert(x); takeGuard_.release(); } catch (ClassCastException ex) { putGuard_.release(); throw ex; } } public boolean offer(Object x, long msecs) throws InterruptedException { if (x == null) throw new IllegalArgumentException(); if (Thread.interrupted()) throw new InterruptedException(); if (!putGuard_.attempt(msecs)) return false; else { try { insert(x); takeGuard_.release(); return true; } catch (ClassCastException ex) { putGuard_.release(); throw ex; } } } public Object take() throws InterruptedException { if (Thread.interrupted()) throw new InterruptedException(); takeGuard_.acquire(); try { Object x = extract(); putGuard_.release(); return x; } catch (ClassCastException ex) { takeGuard_.release(); throw ex; } } public Object poll(long msecs) throws InterruptedException { if (Thread.interrupted()) throw new InterruptedException(); if (!takeGuard_.attempt(msecs)) return null; else { try { Object x = extract(); putGuard_.release(); return x; } catch (ClassCastException ex) { takeGuard_.release(); throw ex; } } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy