Interface BoundedConcurrentHashMap.EvictionPolicy<K,V>
- Enclosing class:
BoundedConcurrentHashMap<K,V>
public static interface BoundedConcurrentHashMap.EvictionPolicy<K,V>
-
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionvoidclear()Invoked to notify EvictionPolicy implementation that all Segment entries have been cleared.createNewEntry(K key, int hash, org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> next, V value) voidexecute()Invokes eviction policy algorithm.booleanonEntryHit(org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> e) Invoked to notify EvictionPolicy implementation that an entry in Segment has been accessed.voidonEntryMiss(org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> e) Invoked to notify EvictionPolicy implementation that there has been an attempt to access an entry in Segment, however that entry was not present in Segment.voidonEntryRemove(org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> e) Invoked to notify EvictionPolicy implementation that an entry e has been removed from Segment.strategy()Returns type of eviction algorithm (strategy).booleanReturns true if batching threshold has expired, false otherwise.
-
Field Details
-
MAX_BATCH_SIZE
static final int MAX_BATCH_SIZE- See Also:
-
-
Method Details
-
createNewEntry
-
execute
void execute()Invokes eviction policy algorithm. -
onEntryMiss
Invoked to notify EvictionPolicy implementation that there has been an attempt to access an entry in Segment, however that entry was not present in Segment.- Parameters:
e- accessed entry in Segment
-
onEntryHit
boolean onEntryHit(org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> e) Invoked to notify EvictionPolicy implementation that an entry in Segment has been accessed. Returns true if batching threshold has been reached, false otherwise.Note that this method is potentially invoked without holding a lock on Segment.
- Parameters:
e- accessed entry in Segment- Returns:
- true if batching threshold has been reached, false otherwise.
-
onEntryRemove
void onEntryRemove(org.hibernate.internal.util.collections.BoundedConcurrentHashMap.HashEntry<K, V> e) Invoked to notify EvictionPolicy implementation that an entry e has been removed from Segment.- Parameters:
e- removed entry in Segment
-
clear
void clear()Invoked to notify EvictionPolicy implementation that all Segment entries have been cleared. -
strategy
BoundedConcurrentHashMap.Eviction strategy()Returns type of eviction algorithm (strategy).- Returns:
- type of eviction algorithm
-
thresholdExpired
boolean thresholdExpired()Returns true if batching threshold has expired, false otherwise.Note that this method is potentially invoked without holding a lock on Segment.
- Returns:
- true if batching threshold has expired, false otherwise.
-