Packages

o

com.twitter.util

Memoize

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

    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
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def apply[A, B](f: (A) ⇒ B): (A) ⇒ B

    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
    Definition Classes
    Any
  6. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  7. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  8. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  9. def finalize(): Unit
    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

    Thread-safe memoization for a Function2.

  11. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  12. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  13. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  16. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  17. def snappable[A, B](f: (A) ⇒ B): Snappable[A, B]

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

  18. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  19. def toString(): String
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped