Package org.terracotta.statistics
Class ValueStatistics
java.lang.Object
org.terracotta.statistics.ValueStatistics
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic <T extends Serializable>
ConstantValueStatistic<T>constant(StatisticType type, T value) static <T extends Number>
ValueStatistic<T>static <T extends Number>
ValueStatistic<T>static <T extends Serializable>
ValueStatistic<T>memoize(long delay, TimeUnit unit, ValueStatistic<T> valueStatistic) Returns aValueStatisticthat caches the value of a statistic for at least a specific amount of time.static <T extends Serializable>
ConstantValueStatistic<T>nullValue(StatisticType type) static <T extends Number>
ValueStatistic<T>static <T extends Number>
ValueStatistic<T>static <T extends Serializable>
ValueStatistic<T>supply(StatisticType type, Supplier<T> supplier) static <T extends Table>
ValueStatistic<T>
-
Constructor Details
-
ValueStatistics
public ValueStatistics()
-
-
Method Details
-
nullValue
-
constant
public static <T extends Serializable> ConstantValueStatistic<T> constant(StatisticType type, T value) -
supply
public static <T extends Serializable> ValueStatistic<T> supply(StatisticType type, Supplier<T> supplier) -
gauge
-
counter
-
rate
-
ratio
-
table
-
memoize
public static <T extends Serializable> ValueStatistic<T> memoize(long delay, TimeUnit unit, ValueStatistic<T> valueStatistic) Returns aValueStatisticthat caches the value of a statistic for at least a specific amount of time.This method does not block.
When the delay expires, if several threads are coming at the same time to read the expired value, then only one will do the update and set a new expiring delay and read the new value. The other threads can continue to read the current expired value for their next call until it gets updated.
If the caching delay is smaller than the time it takes for a statistic value to be computed, then it is possible that a new thread starts asking for a new value before the previous update is completed. In this case, there is no guarantee that the cached value will be updated in order because it depends on the time took to get the new value.
- Type Parameters:
T- The statistic type- Parameters:
delay- The delayunit- The unit of timevalueStatistic- The delegate statistic that will provide the value- Returns:
- the memoizing statistic
-