final class KeyPool[F[_], Key, Rezource] extends AnyRef
This pools internal guarantees are that the max number of values are in the pool at any time, not maximum number of operations. To do the latter application level bounds should be used.
A background reaper thread is kept alive for the length of the key pools life.
When resources are taken from the pool they are received as a Managed. This Managed has a Ref to a Reusable which indicates whether or not the pool can reuse the resource.
(I have a commented create function introducing this functionality here, so it may be introduced later.)
- Source
- KeyPool.scala
- Alphabetic
- By Inheritance
- KeyPool
- AnyRef
- Any
- Hide All
- Show All
- Public
- All
Value Members
- final def !=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def ##(): Int
- Definition Classes
- AnyRef → Any
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- def clone(): AnyRef
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @native() @throws(classOf[java.lang.CloneNotSupportedException])
- def doOnCreate(f: (Key, Rezource) ⇒ F[Unit]): KeyPool[F, Key, Rezource]
An action to take with the Key, Resource pair directly after it has been initially created
- def doOnDestroy(f: (Key, Rezource) ⇒ F[Unit]): KeyPool[F, Key, Rezource]
An action to take with the key, resource pair directly prior to permanently destroying the resource
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- def equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- def finalize(): Unit
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable])
- final def getClass(): Class[_]
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
- def hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
- def put(k: Key, r: Rezource): F[Unit]
Place a Resource into the pool, following the rules for addition for this pool.
Place a Resource into the pool, following the rules for addition for this pool. The Resouce may be shutdown if the pool is already full in either perKey or maxTotal dimensions.
- def state: F[(Int, Map[Key, Int])]
The current state of the pool.
The current state of the pool.
The left value is the total number of resources currently in the pool, and the right is a map of how many resources exist for each key.
- final def synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
- def take(k: Key): Resource[F, Managed[F, Rezource]]
Take a Managed from the Pool.
Take a Managed from the Pool. For the lifetime of this resource this is exclusively available to this key.
At the end of the resource lifetime the state of the resource controls whether it is submitted back to the pool or removed.
- def toString(): String
- Definition Classes
- AnyRef → Any
- final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @throws(classOf[java.lang.InterruptedException])