Scala Library: scala.ref.SoftReference
scala.ref.SoftReference
class SoftReference[+T <: AnyRef] extends ReferenceWrapper[T]
Value Members From scala.Proxy
def equals(that: Any): Boolean
Compares the receiver object ( this
) with the argument object ( that
) for
equivalence.
Any implementation of this method should be an equivalence relation :
- It is reflexive: for any instance
x
of typeAny
,x.equals(x)
should returntrue
. - It is symmetric: for any instances
x
andy
of typeAny
,x.equals(y)
should returntrue
if and only ify.equals(x)
returnstrue
. - It is transitive: for any instances
x
,y
, andz
of typeAny
ifx.equals(y)
returnstrue
andy.equals(z)
returnstrue
, thenx.equals(z)
should returntrue
.
If you override this method, you should verify that your implementation remains
an equivalence relation. Additionally, when overriding this method it is usually
necessary to override hashCode
to ensure that objects which are “equal” (
o1.equals(o2)
returns true
) hash to the same scala.Int. (
o1.hashCode.equals(o2.hashCode)
).
- that
- the object to compare against this object for equality.
- returns
true
if the receiver object is equivalent to the argument;false
otherwise.
- Definition Classes
- Proxy → Any
(defined at scala.Proxy)
Instance Constructors From scala.ref.SoftReference
new SoftReference(value: T)
(defined at scala.ref.SoftReference)
Full Source:
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2006-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala.ref
/**
* @author Sean McDirmid
*/
class SoftReference[+T <: AnyRef](value : T, queue : ReferenceQueue[T]) extends ReferenceWrapper[T] {
def this(value : T) = this(value, null)
val underlying: java.lang.ref.SoftReference[_ <: T] =
new SoftReferenceWithWrapper[T](value, queue, this)
}
/**
* A companion object that implements an extractor for `SoftReference` values
* @author Rebecca Claire Murphy
*/
object SoftReference {
/** Creates a `SoftReference` pointing to `value` */
def apply[T <: AnyRef](value: T) = new SoftReference(value)
/** Optionally returns the referenced value, or `None` if that value no longer exists */
def unapply[T <: AnyRef](sr: SoftReference[T]): Option[T] = Option(sr.underlying.get)
}
/**
* @author Philipp Haller
*/
private class SoftReferenceWithWrapper[T <: AnyRef](value: T, queue: ReferenceQueue[T], val wrapper: SoftReference[T])
extends java.lang.ref.SoftReference[T](value, if (queue == null) null else queue.underlying.asInstanceOf[java.lang.ref.ReferenceQueue[T]]) with ReferenceWithWrapper[T]
Interested in Scala?
I send out weekly, personalized emails with articles and conference talks.
Subscribe now.