Interface InvocableMap<K,V> 
- Type Parameters:
- K- the type of the Map entry keys
- V- the type of the Map entry values
- All Superinterfaces:
- Map<K,- V> 
- All Known Subinterfaces:
- NamedCache<K,,- V> - NamedMap<K,- V> 
- All Known Implementing Classes:
- BundlingNamedCache,- ContinuousQueryCache,- ConverterCollections.ConverterInvocableMap,- ConverterCollections.ConverterNamedCache,- NearCache,- ReadonlyNamedCache,- VersionedNearCache,- WrapperNamedCache
Note: The Partitioned Cache implements the InvocableMap interface by partitioning and localizing the invocations, resulting in extremely high throughput and low latency.
- Since:
- Coherence 3.1
- Author:
- cp/gg/jh 2005.07.19, as 2014.06.14
- 
Nested Class SummaryNested ClassesModifier and TypeInterfaceDescriptionstatic interfaceAn InvocableMap.Entry contains additional information and exposes additional operations that the basic Map.Entry does not.static interfaceAn EntryAggregator represents processing that can be directed to occur against some subset of the entries in an InvocableMap, resulting in a aggregated result.static interfaceAn invocable agent that operates against the Entry objects within a Map.static interfaceDeprecated.This interface was deprecated in Coherence 12.2.1 and might be removed in a future release.static interfaceA StreamingAggregator is an extension ofInvocableMap.EntryAggregatorthat processes entries in a streaming fashion and provides better control overexecution characteristics.
- 
Method SummaryModifier and TypeMethodDescription<R> Raggregate(Filter filter, InvocableMap.EntryAggregator<? super K, ? super V, R> aggregator) Perform an aggregating operation against the set of entries that are selected by the given Filter.default <R> Raggregate(InvocableMap.EntryAggregator<? super K, ? super V, R> aggregator) Perform an aggregating operation against all the entries.<R> Raggregate(Collection<? extends K> collKeys, InvocableMap.EntryAggregator<? super K, ? super V, R> aggregator) Perform an aggregating operation against the entries specified by the passed keys.default VCompute a new mapping for the specified key and its current value.default Vdefault VcomputeIfAbsent(K key, Remote.Function<? super K, ? extends V> mappingFunction) Compute the value using the given mapping function and enter it into this map (unlessnull), if the specified key is not already associated with a value (or is mapped tonull).default VcomputeIfAbsent(K key, Function<? super K, ? extends V> mappingFunction) Note that the previous example will not work as expected if this method is called on a distributed map, as theaddmethod will be called on a client-side copy of the collection stored on the server.default VcomputeIfPresent(K key, Remote.BiFunction<? super K, ? super V, ? extends V> remappingFunction) Compute a new mapping given the key and its current mapped value, if the value for the specified key is present and non-null.default VcomputeIfPresent(K key, BiFunction<? super K, ? super V, ? extends V> remappingFunction) default VgetOrDefault(Object key, V defaultValue) <R> Rinvoke(K key, InvocableMap.EntryProcessor<K, V, R> processor) Invoke the passed EntryProcessor against the Entry specified by the passed key, returning the result of the invocation.invokeAll(Filter filter, InvocableMap.EntryProcessor<K, V, R> processor) Invoke the passed EntryProcessor against the set of entries that are selected by the given Filter, returning the result of the invocation for each.invokeAll(InvocableMap.EntryProcessor<K, V, R> processor) Invoke the passed EntryProcessor against all the entries, returning the result of the invocation for each.invokeAll(Collection<? extends K> collKeys, InvocableMap.EntryProcessor<K, V, R> processor) Invoke the passed EntryProcessor against the entries specified by the passed keys, returning the result of the invocation for each.default VIf the specified key is not already associated with a value or is associated with null, associates it with the given non-null value.default Vdefault VputIfAbsent(K key, V value) default booleandefault Vdefault booleandefault voidreplaceAll(Filter filter, Remote.BiFunction<? super K, ? super V, ? extends V> function) Replace each entry's value with the result of invoking the given function on that entry until all entries selected by the specified filter have been processed or the function throws an exception.default voidreplaceAll(Remote.BiFunction<? super K, ? super V, ? extends V> function) Replace each entry's value with the result of invoking the given function on that entry until all entries have been processed or the function throws an exception.default voidreplaceAll(Collection<? extends K> collKeys, Remote.BiFunction<? super K, ? super V, ? extends V> function) Replace each entry's value with the result of invoking the given function on that entry until all entries for the specified key set have been processed or the function throws an exception.default voidreplaceAll(BiFunction<? super K, ? super V, ? extends V> function) default RemoteStream<InvocableMap.Entry<K, V>> stream()Return a stream of all entries in this map.default RemoteStream<InvocableMap.Entry<K, V>> Return a filtered stream of entries in this map.default <T,E> RemoteStream <E> stream(Filter filter, ValueExtractor<T, ? extends E> extractor) Return a stream of values extracted from all the entries that satisfy the specified filter.default <T,E> RemoteStream <E> stream(ValueExtractor<T, ? extends E> extractor) Return a stream of values extracted from the entries of this map.default RemoteStream<InvocableMap.Entry<K, V>> stream(Collection<? extends K> collKeys) Return a stream of entries with the specified keys.default <T,E> RemoteStream <E> stream(Collection<? extends K> collKeys, ValueExtractor<T, ? extends E> extractor) Return a stream of values extracted from the entries with the specified keys.
- 
Method Details- 
invokeInvoke the passed EntryProcessor against the Entry specified by the passed key, returning the result of the invocation.- Type Parameters:
- R- the type of value returned by the EntryProcessor
- Parameters:
- key- the key to process; it is not required to exist within the Map
- processor- the EntryProcessor to use to process the specified key
- Returns:
- the result of the invocation as returned from the EntryProcessor
 
- 
invokeAllInvoke the passed EntryProcessor against all the entries, returning the result of the invocation for each.- Type Parameters:
- R- the type of value returned by the EntryProcessor
- Parameters:
- processor- the EntryProcessor to use to process the specified keys
- Returns:
- a Map containing the results of invoking the EntryProcessor against each of the specified keys
 
- 
invokeAll<R> Map<K,R> invokeAll(Collection<? extends K> collKeys, InvocableMap.EntryProcessor<K, V, R> processor) Invoke the passed EntryProcessor against the entries specified by the passed keys, returning the result of the invocation for each.- Type Parameters:
- R- the type of value returned by the EntryProcessor
- Parameters:
- collKeys- the keys to process; these keys are not required to exist within the Map
- processor- the EntryProcessor to use to process the specified keys
- Returns:
- a Map containing the results of invoking the EntryProcessor against each of the specified keys
 
- 
invokeAllInvoke the passed EntryProcessor against the set of entries that are selected by the given Filter, returning the result of the invocation for each.Unless specified otherwise, InvocableMap implementations will perform this operation in two steps: (1) use the filter to retrieve a matching entry set; (2) apply the agent to every filtered entry. This algorithm assumes that the agent's processing does not affect the result of the specified filter evaluation, since the filtering and processing could be performed in parallel on different threads. If this assumption does not hold, the processor logic has to be idempotent, or at least re-evaluate the filter. This could be easily accomplished by wrapping the processor with the ConditionalProcessor.- Type Parameters:
- R- the type of value returned by the EntryProcessor
- Parameters:
- filter- a Filter that results in the set of keys to be processed
- processor- the EntryProcessor to use to process the specified keys
- Returns:
- a Map containing the results of invoking the EntryProcessor against the keys that are selected by the given Filter
 
- 
aggregatePerform an aggregating operation against all the entries.- Type Parameters:
- R- the type of value returned by the EntryAggregator
- Parameters:
- aggregator- the EntryAggregator that is used to aggregate across the specified entries of this Map
- Returns:
- the result of the aggregation
 
- 
aggregate<R> R aggregate(Collection<? extends K> collKeys, InvocableMap.EntryAggregator<? super K, ? super V, R> aggregator) Perform an aggregating operation against the entries specified by the passed keys.- Type Parameters:
- R- the type of value returned by the EntryAggregator
- Parameters:
- collKeys- the Collection of keys that specify the entries within this Map to aggregate across
- aggregator- the EntryAggregator that is used to aggregate across the specified entries of this Map
- Returns:
- the result of the aggregation
 
- 
aggregatePerform an aggregating operation against the set of entries that are selected by the given Filter.- Type Parameters:
- R- the type of value returned by the EntryAggregator
- Parameters:
- filter- the Filter that is used to select entries within this Map to aggregate across
- aggregator- the EntryAggregator that is used to aggregate across the selected entries of this Map
- Returns:
- the result of the aggregation
 
- 
getOrDefault- Specified by:
- getOrDefaultin interface- Map<K,- V> 
 
- 
putIfAbsent- Specified by:
- putIfAbsentin interface- Map<K,- V> 
 
- 
remove
- 
replace
- 
replace
- 
computeIfAbsentCompute the value using the given mapping function and enter it into this map (unlessnull), if the specified key is not already associated with a value (or is mapped tonull).If the mapping function returns nullno mapping is recorded. If the function itself throws an (unchecked) exception, the exception is rethrown, and no mapping is recorded.The most common usage is to construct a new object serving as an initial mapped value or memoized result, as in: map.computeIfAbsent(key, k -> new Value(f(k)));Or to implement a multi-value map, Map<K, Collection<V>>, supporting multiple values per key:
 Note that the previous example will not work as expected if this method is called on a distributed map, as themap.computeIfAbsent(key, k -> new HashSet<V>()).add(v);addmethod will be called on the client-side copy of the collection stored on the server.- Parameters:
- key- key with which the specified value is to be associated
- mappingFunction- the function to compute a value
- Returns:
- the current (existing or computed) value associated with the specified key, or null if the computed value is null
 
- 
computeIfAbsentNote that the previous example will not work as expected if this method is called on a distributed map, as theaddmethod will be called on a client-side copy of the collection stored on the server.- Specified by:
- computeIfAbsentin interface- Map<K,- V> 
 
- 
computeIfPresentdefault V computeIfPresent(K key, Remote.BiFunction<? super K, ? super V, ? extends V> remappingFunction) Compute a new mapping given the key and its current mapped value, if the value for the specified key is present and non-null.If the function returns null, the mapping is removed. If the function itself throws an (unchecked) exception, the exception is rethrown, and the current mapping is left unchanged.- Parameters:
- key- the key with which the specified value is to be associated
- remappingFunction- the function to compute a value
- Returns:
- the new value associated with the specified key, or null if none
 
- 
computeIfPresent- Specified by:
- computeIfPresentin interface- Map<K,- V> 
 
- 
computeCompute a new mapping for the specified key and its current value.If the function returns null, the mapping is removed (or remains absent if initially absent). If the function itself throws an (unchecked) exception, the exception is rethrown, and the current mapping is left unchanged.- Parameters:
- key- the key with which the computed value is to be associated
- remappingFunction- the function to compute a value
- Returns:
- the new value associated with the specified key, or null if none
 
- 
compute
- 
mergedefault V merge(K key, V value, Remote.BiFunction<? super V, ? super V, ? extends V> remappingFunction) If the specified key is not already associated with a value or is associated with null, associates it with the given non-null value. Otherwise, replaces the associated value with the results of the given remapping function, or removes if the result isnull.This method may be of use when combining multiple mapped values for a key. For example, to either create or append a String msgto a value mapping:
 If the function returnsmap.merge(key, msg, String::concat)nullthe mapping is removed. If the function itself throws an (unchecked) exception, the exception is rethrown, and the current mapping is left unchanged.- Parameters:
- key- key with which the resulting value is to be associated
- value- the non-null value to be merged with the existing value associated with the key or, if no existing value or a null value is associated with the key, to be associated with the key
- remappingFunction- the function to recompute a value if present
- Returns:
- the new value associated with the specified key, or null if no value is associated with the key
 
- 
merge
- 
replaceAllReplace each entry's value with the result of invoking the given function on that entry until all entries have been processed or the function throws an exception.Exceptions thrown by the function are relayed to the caller. - Parameters:
- function- the function to apply to each entry
 
- 
replaceAll- Specified by:
- replaceAllin interface- Map<K,- V> 
 
- 
replaceAlldefault void replaceAll(Collection<? extends K> collKeys, Remote.BiFunction<? super K, ? super V, ? extends V> function) Replace each entry's value with the result of invoking the given function on that entry until all entries for the specified key set have been processed or the function throws an exception.Exceptions thrown by the function are relayed to the caller. - Parameters:
- collKeys- the keys to process; these keys are not required to exist within the Map
- function- the function to apply to each entry
 
- 
replaceAllReplace each entry's value with the result of invoking the given function on that entry until all entries selected by the specified filter have been processed or the function throws an exception.Exceptions thrown by the function are relayed to the caller. - Parameters:
- filter- the filter that should be used to select entries
- function- the function to apply to each entry
 
- 
streamReturn a stream of all entries in this map.- Returns:
- a stream of all entries in this map
 
- 
streamReturn a stream of entries with the specified keys.- Parameters:
- collKeys- the keys to process; these keys are not required to exist within the Map
- Returns:
- a stream of entries for the specified keys
 
- 
streamReturn a filtered stream of entries in this map.- Parameters:
- filter- filter to apply to this map's entries before creating the stream
- Returns:
- a stream of entries that satisfy the specified filter
 
- 
streamReturn a stream of values extracted from the entries of this map.This method is highly recommended when the intention is to work against a stream of InvocableMap.Entryattributes, and is functionally equivalent to:cache.stream().map(entry -> entry.extract(extractor))The use of this method over thestream()method, allows relevant indices to be used avoiding potential deserialization and significantly improving performance of value extraction.The same goal can be achieved by simply using multiple RemoteStream.map(ValueExtractor)calls against the entry stream, such as:cache.stream() .map(Map.Entry::getValue) .map(MyValue::getAttribute)However, this will only be efficient if you have aDeserializationAcceleratorconfigured for the cache. Otherwise, it will result in deserialization of all cache entries, which is likely to have significant negative impact on performance.- Type Parameters:
- T- the type of the value to extract from
- E- the type of value that will be extracted
- Parameters:
- extractor- the extractor to use
- Returns:
- a stream of extracted values from the entries of this map
 
- 
streamdefault <T,E> RemoteStream<E> stream(Collection<? extends K> collKeys, ValueExtractor<T, ? extends E> extractor) Return a stream of values extracted from the entries with the specified keys.This method is highly recommended when the intention is to work against a stream of InvocableMap.Entryattributes, and is functionally equivalent to:cache.stream(collKeys).map(entry -> entry.extract(extractor))The use of this method over thestream(Collection)method, allows relevant indices to be used avoiding potential deserialization and significantly improving performance of value extraction.The same goal can be achieved by simply using multiple RemoteStream.map(ValueExtractor)calls against the entry stream, such as:cache.stream(collKeys) .map(Map.Entry::getValue) .map(MyValue::getAttribute)However, this will only be efficient if you have aDeserializationAcceleratorconfigured for the cache. Otherwise, it will result in deserialization of all selected entries, which is likely to have significant negative impact on performance.- Type Parameters:
- T- the type of the value to extract from
- E- the type of value that will be extracted
- Parameters:
- collKeys- the keys to process; these keys are not required to exist within the Map
- extractor- the extractor to use
- Returns:
- a stream of values extracted from all the entries with the specified keys
 
- 
streamReturn a stream of values extracted from all the entries that satisfy the specified filter.This method is highly recommended when the intention is to work against a stream of InvocableMap.Entryattributes, and is functionally equivalent to:cache.stream(filter).map(entry -> entry.extract(extractor))The use of this method over thestream(Filter)method, allows relevant indices to be used avoiding potential deserialization and significantly improving performance of value extraction.The same goal can be achieved by simply using multiple RemoteStream.map(ValueExtractor)calls against the entry stream, such as:cache.stream(filter) .map(Map.Entry::getValue) .map(MyValue::getAttribute)However, this will only be efficient if you have aDeserializationAcceleratorconfigured for the cache. Otherwise, it will result in deserialization of all selected entries, which is likely to have significant negative impact on performance.- Type Parameters:
- T- the type of the value to extract from
- E- the type of value that will be extracted
- Parameters:
- filter- filter to apply to this map's entries before creating the stream
- extractor- the extractor to use
- Returns:
- a stream of values extracted from all the entries that satisfy the specified filter
 
 
-