Interface BoundedConcurrentHashMap.EvictionPolicy<K,V>
- Enclosing class:
- BoundedConcurrentHashMap<K,
V>
public static interface BoundedConcurrentHashMap.EvictionPolicy<K,V>
-
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionvoid
clear()
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) void
execute()
Invokes eviction policy algorithm.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.void
onEntryMiss
(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.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.strategy()
Returns type of eviction algorithm (strategy).boolean
Returns 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.
-