クラス CaffeineCache

実装されたすべてのインターフェース:
Cache

public class CaffeineCache extends AbstractValueAdaptingCache
Caffeine Cache インスタンスの上にある Spring Cache アダプターの実装。

CaffeineCache(String, AsyncCache, boolean) コンストラクターを介して提供される場合、Caffeine の AsyncCache を通じて retrieve(Object) および retrieve(Object, Supplier) 操作をサポートします。

Spring Framework 6.1 以降では Caffeine 3.0 以降が必要です。

導入:
4.3
作成者:
Ben Manes, Juergen Hoeller, Stephane Nicoll
関連事項:
  • コンストラクターの詳細

    • CaffeineCache

      public CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> cache)
      使用する指定された名前と指定された内部 Cache で CaffeineCache インスタンスを作成します。
      パラメーター:
      name - キャッシュの名前
      cache - バッキング Caffeine キャッシュインスタンス
    • CaffeineCache

      public CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> cache, boolean allowNullValues)
      使用する指定された名前と指定された内部 Cache で CaffeineCache インスタンスを作成します。
      パラメーター:
      name - キャッシュの名前
      cache - バッキング Caffeine キャッシュインスタンス
      allowNullValues - このキャッシュの null 値を受け入れて変換するかどうか
    • CaffeineCache

      public CaffeineCache(StringSE name, com.github.benmanes.caffeine.cache.AsyncCache<ObjectSE,ObjectSE> cache, boolean allowNullValues)
      使用する指定された名前と指定された内部 AsyncCache で CaffeineCache インスタンスを作成します。
      パラメーター:
      name - キャッシュの名前
      cache - バッキング Caffeine AsyncCache インスタンス
      allowNullValues - このキャッシュの null 値を受け入れて変換するかどうか
      導入:
      6.1
  • メソッドの詳細

    • getName

      public final StringSE getName()
      インターフェースからコピーされた説明: Cache
      キャッシュ名を返します。
    • getNativeCache

      public final com.github.benmanes.caffeine.cache.Cache<ObjectSE,ObjectSE> getNativeCache()
      内部 Caffeine キャッシュ (おそらく getAsyncCache() 上のアダプター) を返します。
    • getAsyncCache

      public final com.github.benmanes.caffeine.cache.AsyncCache<ObjectSE,ObjectSE> getAsyncCache()
      内部 Caffeine AsyncCache を返します。
      例外:
      IllegalStateExceptionSE - AsyncCache が利用できない場合
      導入:
      6.1
      関連事項:
    • get

      @Nullable public <T> T get(ObjectSE key, CallableSE<T> valueLoader)
      インターフェースからコピーされた説明: Cache
      このキャッシュが指定されたキーをマップする値を返し、必要に応じて valueLoader からその値を取得します。このメソッドは、従来の「キャッシュされている場合は返す、そうでない場合は作成、キャッシュして返す」パターンの単純な代替を提供します。

      可能な場合、実装は、同じキーへの同時アクセスの場合に指定された valueLoader が 1 回だけ呼び出されるように、ロード操作が同期されることを確認する必要があります。

      valueLoader が例外をスローした場合、Cache.ValueRetrievalException にラップされます

      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      このキャッシュが指定されたキーをマップする値
      関連事項:
    • retrieve

      @Nullable public CompletableFutureSE<?> retrieve(ObjectSE key)
      インターフェースからコピーされた説明: Cache
      このキャッシュが指定されたキーをマップする値を CompletableFutureSE でラップして返します。この操作はブロックしてはなりませんが、対応する値がすぐに使用できる場合は、完了した CompletableFutureSE を返すことができます。

      キャッシュにこのキーのマッピングが含まれていないことがすぐに判断できる場合 (たとえば、メモリ内のキーマップを通じて)、null を返すことができます。それ以外の場合、キャッシュされた値は CompletableFutureSE に返され、null は後から判断されたキャッシュミスを示します。ネストされた Cache.ValueWrapper は、null 許容のキャッシュされた値を示す可能性があります。null 値がサポートされていない場合は、キャッシュされた値がプレーン要素として表されることもあります。呼び出しコードは、このメソッドによって返される結果のすべてのバリアントを処理できるように準備する必要があります。

      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      このキャッシュが指定されたキーをマップする値。CompletableFutureSE 内に含まれます。キャッシュミスが後で決定された場合は空になる可能性もあります。ストレートな null が返された場合は、キャッシュがこのキーのマッピングが含まれていないと即座に判断されたことを意味します。CompletableFuture 内に含まれる Cache.ValueWrapper は、潜在的に null であるキャッシュされた値を示します。これは、通常の CompletableFuture に含まれる null がキャッシュミスを示す、後で決定されるシナリオでは賢明です。ただし、キャッシュが null 値の実際のキャッシュをサポートしていない場合は、余分なレベルの値の折り返しを回避してプレーン値を返すこともあります。Spring のキャッシュ処理は、こうしたすべての実装戦略に対応できます。
      関連事項:
    • retrieve

      public <T> CompletableFutureSE<T> retrieve(ObjectSE key, SupplierSE<CompletableFutureSE<T>> valueLoader)
      インターフェースからコピーされた説明: Cache
      このキャッシュが指定されたキーをマップする値を返し、必要に応じて valueLoader からその値を取得します。このメソッドは、CompletableFutureSE に基づいた、従来の「キャッシュされている場合は返す、そうでない場合は作成、キャッシュして返す」パターンの単純な代替手段を提供します。この操作はブロックしないでください。

      可能な場合、実装は、同じキーへの同時アクセスの場合に指定された valueLoader が 1 回だけ呼び出されるように、ロード操作が同期されることを確認する必要があります。

      このメソッドでは、NULL 値は常にユーザーレベルの null 値を示します。提供された CompletableFutureSE ハンドルは値を生成するか、例外を生成します。valueLoader が例外を発生させた場合、その例外は返された CompletableFuture ハンドルに伝播されます。

      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      このキャッシュが指定されたキーをマップする値。CompletableFutureSE 内に含まれますが、null になることはありません。提供された Future は、値を生成するか、例外を発生させることが期待されます。
      関連事項:
    • lookup

      @Nullable protected ObjectSE lookup(ObjectSE key)
      クラスからコピーされた説明: AbstractValueAdaptingCache
      基になるストアで実際のルックアップを実行します。
      次で指定:
      クラス AbstractValueAdaptingCachelookup 
      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      キーの生のストア値、ない場合は null 
    • put

      public void put(ObjectSE key, @Nullable ObjectSE value)
      インターフェースからコピーされた説明: Cache
      指定された値をこのキャッシュ内の指定されたキーに関連付けます。

      キャッシュに以前にこのキーのマッピングが含まれていた場合、古い値は指定された値に置き換えられます。

      実際の登録は非同期方式または遅延方式で実行できますが、その後の検索ではエントリがまだ表示されていない可能性があります。これは、たとえばトランザクションキャッシュデコレータの場合です。Cache.putIfAbsent(java.lang.Object, java.lang.Object) を使用して、即時登録を保証します。

      キャッシュが CompletableFutureSE およびリアクティブインタラクションと互換性があると想定されている場合、put 操作は事実上ノンブロッキングであり、バックエンドのライトスルーは非同期で発生する必要があります。これは、Cache.retrieve(Object) および Cache.retrieve(Object, Supplier) をサポートするように実装および構成されたキャッシュとともに行われます。

      パラメーター:
      key - 指定された値が関連付けられるキー
      value - 指定されたキーに関連付けられる値
      関連事項:
    • putIfAbsent

      @Nullable public Cache.ValueWrapper putIfAbsent(ObjectSE key, @Nullable ObjectSE value)
      インターフェースからコピーされた説明: Cache
      指定された値が設定されていない場合、指定された値をこのキャッシュ内の指定されたキーと原子的に関連付けます。

      これは次と同等です:

      
       ValueWrapper existingValue = cache.get(key);
       if (existingValue == null) {
           cache.put(key, value);
       }
       return existingValue;
       
      ただし、アクションはアトミックに実行されます。すべてのすぐに使用できる CacheManager 実装は put をアトミックに実行できますが、操作は、たとえば、存在の確認とそれに続く put という非アトミックな方法で 2 つのステップで実装することもできます。詳細については、使用しているネイティブキャッシュ実装のドキュメントを確認してください。

      デフォルトの実装は、上記のコードスニペットの行に沿って Cache.get(Object) および Cache.put(Object, Object) に委譲します。

      パラメーター:
      key - 指定された値が関連付けられるキー
      value - 指定されたキーに関連付けられる値
      戻り値:
      このキャッシュが指定されたキー(null 自体の場合もある)をマップする値、またはこの呼び出しの前にキャッシュにそのキーのマッピングが含まれていなかった場合は null したがって、null を返すことは、指定された value がキーに関連付けられていることを示すインジケーターです。
      関連事項:
    • evict

      public void evict(ObjectSE key)
      インターフェースからコピーされた説明: Cache
      このキーが存在する場合、このキャッシュからこのキーのマッピングを削除します。

      実際のエビクションは非同期方式または遅延方式で実行できますが、その後のルックアップではおそらくエントリが引き続き表示されます。これは、たとえばトランザクションキャッシュデコレータの場合です。Cache.evictIfPresent(java.lang.Object) を使用して、即時の削除を保証します。

      キャッシュが CompletableFutureSE およびリアクティブインタラクションと互換性があると想定されている場合、エビクト操作は事実上ノンブロッキングであり、バックエンドのライトスルーは非同期で発生する必要があります。これは、Cache.retrieve(Object) および Cache.retrieve(Object, Supplier) をサポートするように実装および構成されたキャッシュとともに行われます。

      パラメーター:
      key - マッピングがキャッシュから削除されるキー
      関連事項:
    • evictIfPresent

      public boolean evictIfPresent(ObjectSE key)
      インターフェースからコピーされた説明: Cache
      このキーが存在する場合は、このキーのマッピングを削除し、以降の検索ではキーがすぐに見えないことを期待します。

      デフォルトの実装は Cache.evict(Object) に委譲し、キーの事前存在が未確定の場合は false を返します。キャッシュプロバイダー、特にキャッシュデコレータは、可能であれば即時の削除を実行し (たとえば、トランザクション内で一般的に遅延されるキャッシュ操作の場合)、指定されたキーの事前存在を確実に判定することが推奨されます。

      パラメーター:
      key - マッピングがキャッシュから削除されるキー
      戻り値:
      キャッシュに以前にこのキーのマッピングがあることがわかっていた場合は true、ない場合は false (または事前の存在を判断できなかった場合)
      関連事項:
    • clear

      public void clear()
      インターフェースからコピーされた説明: Cache
      すべてのマッピングを削除してキャッシュをクリアします。

      実際の消去は、非同期または遅延方式で実行され、その後のルックアップでエントリが引き続き表示される可能性があります。これは、たとえばトランザクションキャッシュデコレータの場合です。Cache.invalidate() を使用して、エントリの即時削除を保証します。

      キャッシュが CompletableFutureSE およびリアクティブインタラクションと互換性があると想定されている場合、クリア操作は事実上ノンブロッキングであり、バックエンドのライトスルーは非同期で発生する必要があります。これは、Cache.retrieve(Object) および Cache.retrieve(Object, Supplier) をサポートするように実装および構成されたキャッシュとともに行われます。

      関連事項:
    • invalidate

      public boolean invalidate()
      インターフェースからコピーされた説明: Cache
      すべてのマッピングを削除してキャッシュを無効にし、以降のルックアップではすべてのエントリがすぐに表示されないようにします。
      戻り値:
      キャッシュにマッピングがあることがわかっている場合は true、マッピングがない場合は false (または、エントリの事前の存在を判別できなかった場合)
      関連事項: