Package com.google.common.cache
Class LocalCache.LoadingValueReference<K,V>
java.lang.Object
com.google.common.cache.LocalCache.LoadingValueReference<K,V>
- All Implemented Interfaces:
LocalCache.ValueReference<K,
V>
- Direct Known Subclasses:
LocalCache.ComputingValueReference
- Enclosing class:
LocalCache<K,
V>
static class LocalCache.LoadingValueReference<K,V>
extends Object
implements LocalCache.ValueReference<K,V>
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) final SettableFuture
<V> (package private) LocalCache.ValueReference
<K, V> (package private) final Stopwatch
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptioncopyFor
(ReferenceQueue<V> queue, V value, ReferenceEntry<K, V> entry) Creates a copy of this reference for the given entry.long
private ListenableFuture
<V> get()
Returns the value.getEntry()
Returns the entry associated with this value reference, ornull
if this value reference is independent of any entry.int
Returns the weight of this entry.boolean
isActive()
Returns true if this reference contains an active value, meaning one that is still considered present in the cache.boolean
Returns true if a new value is currently loading, regardless of whether there is an existing value.loadFuture
(K key, CacheLoader<? super K, V> loader) void
notifyNewValue
(V newValue) Notify pending loads that a new value was set.boolean
boolean
Waits for a value that may still be loading.
-
Field Details
-
oldValue
-
futureValue
-
stopwatch
-
-
Constructor Details
-
LoadingValueReference
public LoadingValueReference() -
LoadingValueReference
-
-
Method Details
-
isLoading
public boolean isLoading()Description copied from interface:LocalCache.ValueReference
Returns true if a new value is currently loading, regardless of whether there is an existing value. It is assumed that the return value of this method is constant for any given ValueReference instance.- Specified by:
isLoading
in interfaceLocalCache.ValueReference<K,
V>
-
isActive
public boolean isActive()Description copied from interface:LocalCache.ValueReference
Returns true if this reference contains an active value, meaning one that is still considered present in the cache. Active values consist of live values, which are returned by cache lookups, and dead values, which have been evicted but awaiting removal. Non-active values consist strictly of loading values, though during refresh a value may be both active and loading.- Specified by:
isActive
in interfaceLocalCache.ValueReference<K,
V>
-
getWeight
public int getWeight()Description copied from interface:LocalCache.ValueReference
Returns the weight of this entry. This is assumed to be static between calls to setValue.- Specified by:
getWeight
in interfaceLocalCache.ValueReference<K,
V>
-
set
-
setException
-
fullyFailedFuture
-
notifyNewValue
Description copied from interface:LocalCache.ValueReference
Notify pending loads that a new value was set. This is only relevant to loading value references.- Specified by:
notifyNewValue
in interfaceLocalCache.ValueReference<K,
V>
-
loadFuture
-
compute
-
elapsedNanos
public long elapsedNanos() -
waitForValue
Description copied from interface:LocalCache.ValueReference
Waits for a value that may still be loading. Unlike get(), this method can block (in the case of FutureValueReference).- Specified by:
waitForValue
in interfaceLocalCache.ValueReference<K,
V> - Throws:
ExecutionException
- if the loading thread throws an exception
-
get
Description copied from interface:LocalCache.ValueReference
Returns the value. Does not block or throw exceptions.- Specified by:
get
in interfaceLocalCache.ValueReference<K,
V>
-
getOldValue
-
getEntry
Description copied from interface:LocalCache.ValueReference
Returns the entry associated with this value reference, ornull
if this value reference is independent of any entry.- Specified by:
getEntry
in interfaceLocalCache.ValueReference<K,
V>
-
copyFor
public LocalCache.ValueReference<K,V> copyFor(ReferenceQueue<V> queue, @CheckForNull V value, ReferenceEntry<K, V> entry) Description copied from interface:LocalCache.ValueReference
Creates a copy of this reference for the given entry.value
may be null only for a loading reference.- Specified by:
copyFor
in interfaceLocalCache.ValueReference<K,
V>
-