Package org.cache2k.operation
Interface TimeReference
-
public interface TimeReferenceTime reference for a cache. By default the current time is retrieved withSystem.currentTimeMillis(). Another time reference can be specified if the application uses a different time source or when a simulated clock should be used.An instance may implement
AutoCloseableif resources need to be cleaned up.- Author:
- Jens Wilke
-
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description longmillis()Returns the milliseconds since epoch.voidsleep(long millis)Wait for the specified amount of time in milliseconds.default longtoMillis(long millis)Convert a value returned bymillis()to milliseconds since epoch.
-
-
-
Method Detail
-
millis
long millis()
Returns the milliseconds since epoch. In the simulated clock a call to this method would make time pass in small increments.It is possible to use other time scales and references (e.g. nano seconds). In this case the method
toMillis(long)needs to be implemented. All times in the cache API, e.g.MutableCacheEntry.getExpiryTime()or inAdvancedCacheLoader.load(Object, long, CacheEntry)be based on the time defined here. That may lead to confusion and should be used with caution.
-
sleep
void sleep(long millis) throws InterruptedExceptionWait for the specified amount of time in milliseconds.The value of 0 means that the thread should pause and other processing should be done. In a simulated clock this would wait for concurrent processing and, if no processing is happening, advance the time to the next event.
- Throws:
InterruptedException
-
toMillis
default long toMillis(long millis)
Convert a value returned bymillis()to milliseconds since epoch. This can be overridden in case another time scale and or reference is used. Conversion is needed for correctly scheduling timer task that regularly process the expiry tasks.
-
-