Class

io.github.andrebeat.pool

ArrayBlockingQueuePool

Related Doc: package pool

Permalink

abstract class ArrayBlockingQueuePool[A <: AnyRef] extends Pool[A]

A generic object pooling implementation based on java.util.concurrent.ArrayBlockingQueue. This implementation relies on the thread-safety and blocking/non-blocking mechanisms of the underlying data structure to implement the pool interface. Furthermore, for synchronization and tracking of live instances an java.util.concurrent.atomic.AtomicInteger is used. No locks are used in this implementation.

The type of items inserted in the queue must implement the Item interface. This class defines methods for consuming the item (e.g. disposing of any resources associated with it) and a method that's called whenever an item is successfully inserted into the queue (useful for triggering a side-effect). This class is also responsible for dealing with the reference type that's wrapping the value (i.e. ensure calling its destructor if the value is defined).

Self Type
ArrayBlockingQueuePool[A]
Linear Supertypes
Pool[A], AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. ArrayBlockingQueuePool
  2. Pool
  3. AnyRef
  4. Any
  1. Hide All
  2. Show all
Visibility
  1. Public
  2. All

Instance Constructors

  1. new ArrayBlockingQueuePool(capacity: Int, referenceType: ReferenceType)

    Permalink

Type Members

  1. abstract class Item extends AnyRef

    Permalink
    Attributes
    protected

Abstract Value Members

  1. abstract def dispose(a: A): Unit

    Permalink

    Object "destructor".

    Object "destructor". This method is called whenever the object is evicted from the pool. For example, when doing connection pooling it is necessary to close the connection whenever it is evicted (i.e. permanently removed) from the pool.

    Attributes
    protected
    Definition Classes
    Pool
  2. abstract def factory(): A

    Permalink

    Factory method for creating new objects.

    Factory method for creating new objects.

    returns

    a new object.

    Attributes
    protected
    Definition Classes
    Pool
  3. abstract def healthCheck(a: A): Boolean

    Permalink

    An health check that is performed on an object before its leased from the pool.

    An health check that is performed on an object before its leased from the pool. If the health check passes the object is successfully leased. Otherwise, the object is destroyed (and a new one is fetched or created)

    Attributes
    protected
    Definition Classes
    Pool
  4. abstract def newItem(a: A): Item

    Permalink
    Attributes
    protected[this]
  5. abstract def reset(a: A): Unit

    Permalink

    Resets the internal state of object.

    Resets the internal state of object. This method is called on an object whenever it is added/released back to the pool. For example, if pooling an object like a java.nio.ByteBuffer it might make sense to call its reset() method whenever the object is released to the pool, so that its future users do not observe the internal state introduced by previous ones.

    Attributes
    protected
    Definition Classes
    Pool

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. def acquire(): Lease[A]

    Permalink

    Acquire a lease for an object blocking if none is available.

    Acquire a lease for an object blocking if none is available.

    returns

    a lease for an object from this pool.

    Definition Classes
    ArrayBlockingQueuePoolPool
  5. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  6. val capacity: Int

    Permalink

    Returns the capacity of the pool, i.e.

    Returns the capacity of the pool, i.e. the maximum number of objects the pool can hold.

    returns

    the capacity of the pool.

    Definition Classes
    ArrayBlockingQueuePoolPool
  7. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. def destroy(a: A): Unit

    Permalink
    Attributes
    protected[this]
    Annotations
    @inline()
  9. final def drain(): Unit

    Permalink

    Drains the object pool, i.e.

    Drains the object pool, i.e. evicts every object currently pooled.

    Definition Classes
    ArrayBlockingQueuePoolPool
    Annotations
    @tailrec()
  10. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  11. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  12. final def fill(): Unit

    Permalink

    Fills the object pool by creating (and pooling) new objects until the number of live objects reaches the pool capacity.

    Fills the object pool by creating (and pooling) new objects until the number of live objects reaches the pool capacity.

    Definition Classes
    ArrayBlockingQueuePoolPool
    Annotations
    @tailrec()
  13. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  14. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  15. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  16. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  17. val items: ArrayBlockingQueue[Item]

    Permalink
    Attributes
    protected[this]
  18. def leased(): Int

    Permalink

    Returns the number of leased objects.

    Returns the number of leased objects.

    The value returned by this method is only accurate when the referenceType is io.github.andrebeat.pool.ReferenceType.Strong, since GC-based eviction is checked only when trying to acquire an object.

    returns

    the number of leased objects.

    Definition Classes
    Pool
  19. def live(): Int

    Permalink

    Returns the number of live objects, i.e.

    Returns the number of live objects, i.e. the number of currently pooled objects plus leased objects.

    The value returned by this method is only accurate when the referenceType is io.github.andrebeat.pool.ReferenceType.Strong, since GC-based eviction is checked only when trying to acquire an object.

    returns

    the number of live objects.

    Definition Classes
    ArrayBlockingQueuePoolPool
  20. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  21. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  22. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  23. val referenceType: ReferenceType

    Permalink

    Returns the io.github.andrebeat.pool.ReferenceType of the objects stored in the pool.

    Returns the io.github.andrebeat.pool.ReferenceType of the objects stored in the pool.

    Definition Classes
    ArrayBlockingQueuePoolPool
  24. def size(): Int

    Permalink

    Returns the number of objects in the pool.

    Returns the number of objects in the pool.

    The value returned by this method is only accurate when the referenceType is io.github.andrebeat.pool.ReferenceType.Strong, since GC-based eviction is checked only when trying to acquire an object.

    returns

    the number of objects in the pool.

    Definition Classes
    ArrayBlockingQueuePoolPool
  25. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  26. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  27. def tryAcquire(atMost: Duration): Option[Lease[A]]

    Permalink

    Try to acquire a lease for an object blocking at most until the given duration.

    Try to acquire a lease for an object blocking at most until the given duration.

    atMost

    maximum wait time for the lease to be available.

    returns

    a lease for an object from this pool if available until the given duration, None otherwise.

    Definition Classes
    ArrayBlockingQueuePoolPool
  28. def tryAcquire(): Option[Lease[A]]

    Permalink

    Try to acquire a lease for an object without blocking.

    Try to acquire a lease for an object without blocking.

    returns

    a lease for an object from this pool if available, None otherwise.

    Definition Classes
    ArrayBlockingQueuePoolPool
  29. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  30. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  31. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Pool[A]

Inherited from AnyRef

Inherited from Any

Ungrouped