public class CaffeineCache extends AbstractValueAdaptingCache
Cache.ValueRetrievalException, Cache.ValueWrapper
コンストラクターと説明 |
---|
CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE, ObjectSE> cache) 使用する指定された名前と指定された内部 Cache で CaffeineCache インスタンスを作成します。 |
CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE, ObjectSE> cache, boolean allowNullValues) 使用する指定された名前と指定された内部 Cache で CaffeineCache インスタンスを作成します。 |
修飾子と型 | メソッドと説明 |
---|---|
void | clear() キャッシュからすべてのマッピングを削除します。 |
void | evict(ObjectSE key) このキーが存在する場合、このキャッシュからこのキーのマッピングを削除します。 |
Cache.ValueWrapper | get(ObjectSE key) このキャッシュが指定されたキーをマップする値を返します。 |
<T> T | get(ObjectSE key, CallableSE<T> valueLoader) このキャッシュが指定されたキーをマップする値を返し、必要に応じて valueLoader からその値を取得します。 |
StringSE | getName() キャッシュ名を返します。 |
com.github.benmanes.caffeine.cache.Cache<ObjectSE, ObjectSE> | getNativeCache() 基になるネイティブキャッシュプロバイダーを返します。 |
protected ObjectSE | lookup(ObjectSE key) 基になるストアで実際のルックアップを実行します。 |
void | put(ObjectSE key, ObjectSE value) 指定された値をこのキャッシュ内の指定されたキーに関連付けます。 |
Cache.ValueWrapper | putIfAbsent(ObjectSE key, ObjectSE value) 指定された値が設定されていない場合、指定された値をこのキャッシュ内の指定されたキーと原子的に関連付けます。 |
fromStoreValue, get, isAllowNullValues, toStoreValue, toValueWrapper
cloneSE, equalsSE, finalizeSE, getClassSE, hashCodeSE, notifySE, notifyAllSE, toStringSE, waitSE, waitSE, waitSE
public CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> cache)
Cache
で CaffeineCache
インスタンスを作成します。name
- キャッシュの名前 cache
- バッキング Caffeine キャッシュインスタンス public CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> cache, boolean allowNullValues)
Cache
で CaffeineCache
インスタンスを作成します。name
- キャッシュの名前 cache
- バッキング Caffeine キャッシュインスタンス allowNullValues
- このキャッシュの null
値を受け入れて変換するかどうか public final com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> getNativeCache()
Cache
@Nullable public Cache.ValueWrapper get(ObjectSE key)
Cache
キャッシュにこのキーのマッピングが含まれていない場合は、null
を返します。そうでない場合、キャッシュされた値(null
自体である可能性があります)が Cache.ValueWrapper
で返されます。
Cache
の get
AbstractValueAdaptingCache
の get
key
- 関連する値が返されるキー Cache.ValueWrapper
内に含まれ、キャッシュされた null
値も保持する場合があります。返されるストレート null
は、キャッシュにこのキーのマッピングが含まれていないことを意味します。Cache.get(Object, Class)
@Nullable public <T> T get(ObjectSE key, CallableSE<T> valueLoader)
Cache
valueLoader
からその値を取得します。このメソッドは、従来の「キャッシュされている場合は返す、そうでない場合は作成、キャッシュして返す」パターンの単純な代替を提供します。 可能な場合、実装は、同じキーへの同時アクセスの場合に指定された valueLoader
が 1 回だけ呼び出されるように、ロード操作が同期されることを確認する必要があります。
valueLoader
が例外をスローした場合、Cache.ValueRetrievalException
にラップされます
key
- 関連する値が返されるキー protected ObjectSE lookup(ObjectSE key)
AbstractValueAdaptingCache
AbstractValueAdaptingCache
の lookup
key
- 関連する値が返されるキー public void put(ObjectSE key, @Nullable ObjectSE value)
Cache
キャッシュに以前にこのキーのマッピングが含まれていた場合、古い値は指定された値に置き換えられます。
key
- 指定された値が関連付けられるキー value
- 指定されたキーに関連付けられる値 @Nullable public Cache.ValueWrapper putIfAbsent(ObjectSE key, @Nullable ObjectSE value)
Cache
これは次と同等です:
Object existingValue = cache.get(key);
if (existingValue == null) {
cache.put(key, value);
return null;
} else {
return existingValue;
}
ただし、アクションはアトミックに実行されます。すべての初期状態の CacheManager
実装は、put をアトミックに実行することができるが、オペレーションは、たとえば、非アトミックな方法で、存在のチェックと後続の put との 2 つのステップで実装することもできます。詳細については、使用しているネイティブキャッシュ実装のドキュメントを参照してください。key
- 指定された値が関連付けられるキー value
- 指定されたキーに関連付けられる値 null
自体の場合もある)をマップする値、またはこの呼び出しの前にキャッシュにそのキーのマッピングが含まれていなかった場合は null
したがって、null
を返すことは、指定された value
がキーに関連付けられていることを示すインジケーターです。public void evict(ObjectSE key)
Cache
key
- マッピングがキャッシュから削除されるキー public void clear()
Cache