Class ConverterCollections.ConverterInvocableMap<FK,TK,FV,TV>
- java.lang.Object
- 
- com.tangosol.util.ConverterCollections.ConverterMap<FK,TK,FV,TV>
- 
- com.tangosol.util.ConverterCollections.ConverterInvocableMap<FK,TK,FV,TV>
 
 
- 
- All Implemented Interfaces:
- InvocableMap<TK,TV>,- Serializable,- Map<TK,TV>
 - Enclosing class:
- ConverterCollections
 
 public static class ConverterCollections.ConverterInvocableMap<FK,TK,FV,TV> extends ConverterCollections.ConverterMap<FK,TK,FV,TV> implements InvocableMap<TK,TV>, Serializable A Converter InvocableMap views an underlying InvocableMap through a set of key and value Converters.- See Also:
- Serialized Form
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface com.tangosol.util.InvocableMapInvocableMap.Entry<K,V>, InvocableMap.EntryAggregator<K,V,R>, InvocableMap.EntryProcessor<K,V,R>, InvocableMap.ParallelAwareAggregator<K,V,P,R>, InvocableMap.StreamingAggregator<K,V,P,R>
 
- 
 - 
Field Summary- 
Fields inherited from class com.tangosol.util.ConverterCollections.ConverterMapm_convKeyDown, m_convKeyUp, m_convValDown, m_convValUp, m_map, m_set
 
- 
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description <R> Raggregate(Filter filter, InvocableMap.EntryAggregator<? super TK,? super TV,R> agent)Perform an aggregating operation against the set of entries that are selected by the given Filter.<R> Raggregate(Collection<? extends TK> collKeys, InvocableMap.EntryAggregator<? super TK,? super TV,R> agent)Perform an aggregating operation against the entries specified by the passed keys.protected static ObjectconvertSafe(Converter converter, Object oValue)Convert the provided value with the given converter.InvocableMap<FK,FV>getInvocableMap()Return the underlying InvocableMap.<R> Rinvoke(TK key, InvocableMap.EntryProcessor<TK,TV,R> agent)Invoke the passed EntryProcessor against the Entry specified by the passed key, returning the result of the invocation.<R> Map<TK,R>invokeAll(Filter filter, InvocableMap.EntryProcessor<TK,TV,R> agent)Invoke the passed EntryProcessor against the set of entries that are selected by the given Filter, returning the result of the invocation for each.<R> Map<TK,R>invokeAll(Collection<? extends TK> collKeys, InvocableMap.EntryProcessor<TK,TV,R> agent)Invoke the passed EntryProcessor against the entries specified by the passed keys, returning the result of the invocation for each.TVmerge(TK key, TV value, Remote.BiFunction<? super TV,? super TV,? extends TV> 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.TVmerge(TK key, TV value, BiFunction<? super TV,? super TV,? extends TV> remappingFunction)TVputIfAbsent(TK key, TV value)booleanremove(Object key, Object value)TVreplace(TK key, TV value)booleanreplace(TK key, TV oldValue, TV newValue)- 
Methods inherited from class com.tangosol.util.ConverterCollections.ConverterMapclear, containsKey, containsValue, entrySet, equals, get, getConverterKeyDown, getConverterKeyUp, getConverterValueDown, getConverterValueUp, getMap, hashCode, instantiateCollection, instantiateEntrySet, instantiateMap, instantiateSet, isEmpty, keySet, put, putAll, remove, size, subMap, toString, values
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface com.tangosol.util.InvocableMapaggregate, compute, compute, computeIfAbsent, computeIfAbsent, computeIfPresent, computeIfPresent, getOrDefault, invokeAll, replaceAll, replaceAll, replaceAll, replaceAll, stream, stream, stream, stream, stream, stream
 
- 
 
- 
- 
- 
Constructor Detail- 
ConverterInvocableMappublic ConverterInvocableMap(InvocableMap<FK,FV> map, Converter<FK,TK> convKeyUp, Converter<TK,FK> convKeyDown, Converter<FV,TV> convValUp, Converter<TV,FV> convValDown) Constructor.- Parameters:
- map- the underlying InvocableMap
- convKeyUp- the Converter to view the underlying InvocableMap's keys through
- convKeyDown- the Converter to use to pass keys down to the underlying InvocableMap
- convValUp- the Converter to view the underlying InvocableMap's values through
- convValDown- the Converter to use to pass values down to the underlying InvocableMap
 
 
- 
 - 
Method Detail- 
aggregatepublic <R> R aggregate(Collection<? extends TK> collKeys, InvocableMap.EntryAggregator<? super TK,? super TV,R> agent) Perform an aggregating operation against the entries specified by the passed keys.- Specified by:
- aggregatein interface- InvocableMap<FK,TK>
- 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
- agent- the EntryAggregator that is used to aggregate across the specified entries of this Map
- Returns:
- the result of the aggregation
 
 - 
aggregatepublic <R> R aggregate(Filter filter, InvocableMap.EntryAggregator<? super TK,? super TV,R> agent) Perform an aggregating operation against the set of entries that are selected by the given Filter.- Specified by:
- aggregatein interface- InvocableMap<FK,TK>
- 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
- agent- the EntryAggregator that is used to aggregate across the selected entries of this Map
- Returns:
- the result of the aggregation
 
 - 
invokepublic <R> R invoke(TK key, InvocableMap.EntryProcessor<TK,TV,R> agent) Invoke the passed EntryProcessor against the Entry specified by the passed key, returning the result of the invocation.- Specified by:
- invokein interface- InvocableMap<FK,TK>
- 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
- agent- the EntryProcessor to use to process the specified key
- Returns:
- the result of the invocation as returned from the EntryProcessor
 
 - 
invokeAllpublic <R> Map<TK,R> invokeAll(Collection<? extends TK> collKeys, InvocableMap.EntryProcessor<TK,TV,R> agent) Invoke the passed EntryProcessor against the entries specified by the passed keys, returning the result of the invocation for each.- Specified by:
- invokeAllin interface- InvocableMap<FK,TK>
- 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
- agent- 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
 
 - 
invokeAllpublic <R> Map<TK,R> invokeAll(Filter filter, InvocableMap.EntryProcessor<TK,TV,R> agent) Invoke 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.- Specified by:
- invokeAllin interface- InvocableMap<FK,TK>
- 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
- agent- 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
 
 - 
putIfAbsentpublic TV putIfAbsent(TK key, TV value) - Specified by:
- putIfAbsentin interface- InvocableMap<FK,TK>
- Specified by:
- putIfAbsentin interface- Map<FK,TK>
 
 - 
mergepublic TV merge(TK key, TV value, Remote.BiFunction<? super TV,? super TV,? extends TV> remappingFunction) Description copied from interface:InvocableMapIf 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.- Specified by:
- mergein interface- InvocableMap<FK,TK>
- 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
 
 - 
mergepublic TV merge(TK key, TV value, BiFunction<? super TV,? super TV,? extends TV> remappingFunction) 
 - 
getInvocableMappublic InvocableMap<FK,FV> getInvocableMap() Return the underlying InvocableMap.- Returns:
- the underlying InvocableMap
 
 - 
convertSafeprotected static Object convertSafe(Converter converter, Object oValue) Convert the provided value with the given converter. If there is an issue in type conversion return the given value.- Parameters:
- converter- the converter to use
- oValue- the value to convert
- Returns:
- a converted value or the original value
 
 
- 
 
-