Class CompactSerializationCache.InternalEvictionPolicy

    • Field Detail

      • m_ldtLastEvict

        protected long m_ldtLastEvict
        The date-time of the last eviction.
      • f_visitorTouchCount

        protected final BinaryLongMap.EntryVisitor f_visitorTouchCount
        The singleton stateless visitor to update the touch-count map.
      • f_visitorTouchTime

        protected final BinaryLongMap.EntryVisitor f_visitorTouchTime
        The singleton stateless visitor to update the touch-time map.
    • Constructor Detail

      • InternalEvictionPolicy

        protected InternalEvictionPolicy()
    • Method Detail

      • requestEviction

        public void requestEviction​(int cMaximum)
        This method is called by the cache when the cache requires the eviction policy to evict entries.
        Specified by:
        requestEviction in interface ConfigurableCacheMap.EvictionPolicy
        Parameters:
        cMaximum - the maximum number of units that should remain in the cache when the eviction is complete
      • getName

        public String getName()
        Obtain the name of the eviction policy. This is intended to be human readable for use in a monitoring tool; examples include "LRU" and "LFU".
        Specified by:
        getName in interface ConfigurableCacheMap.EvictionPolicy
        Returns:
        the name of the eviction policy
      • calculateWeight

        protected abstract long calculateWeight​(Binary binKey)
        Calculate the "weight" of the entry associated with the specified key. The weight is a quantitative measure of how to prioritize the eviction of this entry w.r.t. the other cache entries. Entries with a smaller weights are of higher priority and are preferred over entries with larger weights for eviction.
        Parameters:
        binKey - the key to calculate the weight for
        Returns:
        the weight of the entry
      • entryTouched

        public void entryTouched​(Binary binKey)
        This method is called by the cache to indicate that the entry for the specified key has been touched.
        Parameters:
        binKey - the key
      • touchInternal

        protected void touchInternal​(Binary binKey)
        Update the internally maintained "touch"-related statistics for the specified key (e.g. touch time and touch count).
        Parameters:
        binKey - the key being touched