Class MetadataMortalCacheEntry

java.lang.Object
org.infinispan.container.entries.AbstractInternalCacheEntry
org.infinispan.container.entries.metadata.MetadataMortalCacheEntry
All Implemented Interfaces:
Cloneable, Map.Entry, CacheEntry, InternalCacheEntry, MetadataAware
Direct Known Subclasses:
L1MetadataInternalCacheEntry

public class MetadataMortalCacheEntry extends AbstractInternalCacheEntry implements MetadataAware
A cache entry that is mortal and is MetadataAware
Since:
5.3
Author:
Galder ZamarreƱo
  • Field Details

    • metadata

      protected Metadata metadata
    • created

      protected long created
  • Constructor Details

    • MetadataMortalCacheEntry

      public MetadataMortalCacheEntry(Object key, Object value, Metadata metadata, long created)
    • MetadataMortalCacheEntry

      protected MetadataMortalCacheEntry(Object key, Object value, PrivateMetadata internalMetadata, Metadata metadata, long created)
  • Method Details

    • isExpired

      public final boolean isExpired(long now)
      Specified by:
      isExpired in interface InternalCacheEntry
      Parameters:
      now - the current time as defined by System.currentTimeMillis() or TimeService.wallClockTime()
      Returns:
      true if the entry has expired; false otherwise
    • canExpire

      public final boolean canExpire()
      Specified by:
      canExpire in interface InternalCacheEntry
      Returns:
      true if the entry can expire, false otherwise
    • getCreated

      public final long getCreated()
      Specified by:
      getCreated in interface CacheEntry
      Returns:
      timestamp when the entry was created
    • getLastUsed

      public final long getLastUsed()
      Specified by:
      getLastUsed in interface CacheEntry
      Returns:
      timestamp when the entry was last used
    • getLifespan

      public final long getLifespan()
      Specified by:
      getLifespan in interface CacheEntry
      Returns:
      retrieves the lifespan of this entry. -1 means an unlimited lifespan.
    • getMaxIdle

      public final long getMaxIdle()
      Specified by:
      getMaxIdle in interface CacheEntry
      Returns:
      the maximum allowed time for which this entry can be idle, after which it is considered expired.
    • getExpiryTime

      public final long getExpiryTime()
      Description copied from interface: InternalCacheEntry
      Only used with entries that have a lifespan, this determines when an entry is due to expire.
      Specified by:
      getExpiryTime in interface InternalCacheEntry
      Returns:
      timestamp when the entry is due to expire, or -1 if it doesn't have a lifespan
    • touch

      public final void touch(long currentTimeMillis)
      Description copied from interface: InternalCacheEntry
      Updates access timestamps on this instance to a specified time
      Specified by:
      touch in interface InternalCacheEntry
      Parameters:
      currentTimeMillis - the current time as defined by System.currentTimeMillis() or TimeService.wallClockTime()
    • reincarnate

      public void reincarnate(long now)
      Description copied from interface: InternalCacheEntry
      "Reincarnates" an entry. Essentially, resets the 'created' timestamp of the entry to the current time.
      Specified by:
      reincarnate in interface InternalCacheEntry
      Parameters:
      now - the current time as defined by System.currentTimeMillis() or TimeService.wallClockTime()
    • toInternalCacheValue

      public InternalCacheValue<?> toInternalCacheValue()
      Description copied from interface: InternalCacheEntry
      Creates a representation of this entry as an InternalCacheValue. The main purpose of this is to provide a representation that does not have a reference to the key. This is useful in situations where the key is already known or stored elsewhere, making serialization and deserialization more efficient.

      Note that this should not be used to optimize memory overhead, since the saving of an additional reference to a key (a single object reference) does not warrant the cost of constructing an InternalCacheValue. This only makes sense when marshalling is involved, since the cost of marshalling the key again can be sidestepped using an InternalCacheValue if the key is already known/marshalled.

      Specified by:
      toInternalCacheValue in interface InternalCacheEntry
      Returns:
      a new InternalCacheValue encapsulating this InternalCacheEntry's value and expiration information.
    • getMetadata

      public Metadata getMetadata()
      Description copied from interface: MetadataAware
      Get metadata of this cache entry.
      Specified by:
      getMetadata in interface MetadataAware
      Overrides:
      getMetadata in class AbstractInternalCacheEntry
      Returns:
      a Metadata instance
    • setMetadata

      public void setMetadata(Metadata metadata)
      Description copied from interface: MetadataAware
      Set the metadata in the cache entry.
      Specified by:
      setMetadata in interface MetadataAware
      Overrides:
      setMetadata in class AbstractInternalCacheEntry
      Parameters:
      metadata - to apply to the cache entry
    • appendFieldsToString

      protected void appendFieldsToString(StringBuilder builder)
      Overrides:
      appendFieldsToString in class AbstractInternalCacheEntry