Object

com.twitter.util

Memoize

Related Doc: package util

Permalink

object Memoize

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Memoize
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. trait Snappable[A, B] extends (A) ⇒ B

    Permalink

    A Snappable is a memoized function for which a scala.collection.immutable.Map of the currently memoized computations can be obtained.

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 apply[A, B](f: (A) ⇒ B): (A) ⇒ B

    Permalink

    Thread-safe memoization for a function.

    Thread-safe memoization for a function.

    This works like a lazy val indexed by the input value. The memo is held as part of the state of the returned function, so keeping a reference to the function will keep a reference to the (unbounded) memo table. The memo table will never forget a result, and will retain a reference to the corresponding input values as well.

    If the computation has side-effects, they will happen exactly once per input, even if multiple threads attempt to memoize the same input at one time, unless the computation throws an exception. If an exception is thrown, then the result will not be stored, and the computation will be attempted again upon the next access. Only one value will be computed at a time. The overhead required to ensure that the effects happen only once is paid only in the case of a miss (once per input over the life of the memo table). Computations for different input values will not block each other.

    The combination of these factors means that this method is useful for functions that will only ever be called on small numbers of inputs, are expensive compared to a hash lookup and the memory overhead, and will be called repeatedly.

  5. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  6. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. final def eq(arg0: AnyRef): Boolean

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

    Permalink
    Definition Classes
    AnyRef → Any
  9. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  10. def function2[A, B, C](f: (A, B) ⇒ C): (A, B) ⇒ C

    Permalink

    Thread-safe memoization for a Function2.

  11. final def getClass(): Class[_]

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

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

    Permalink
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean

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

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

    Permalink
    Definition Classes
    AnyRef
  17. def snappable[A, B](f: (A) ⇒ B): Snappable[A, B]

    Permalink

    Produces com.twitter.util.Memoize.Snappable, thread-safe memoization for a function.

  18. final def synchronized[T0](arg0: ⇒ T0): T0

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

    Permalink
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit

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

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

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

Inherited from AnyRef

Inherited from Any

Ungrouped