パッケージ org.springframework.cache

インターフェース Cache

すべての既知の実装クラス:
AbstractValueAdaptingCacheCaffeineCacheConcurrentMapCacheJCacheCacheNoOpCacheTransactionAwareCacheDecorator

public interface Cache
一般的なキャッシュ操作を定義するインターフェース。: キャッシュは一般的に使用されるため、実装で null 値の格納を許可することをお勧めします (たとえば、null を返すメソッドをキャッシュするため)。
導入:
3.1
作成者:
Costin Leau, Juergen Hoeller, Stephane Nicoll
  • ネストされたクラスのサマリー

    ネストされたクラス
    修飾子と型
    インターフェース
    説明
    static class
    値ローダーコールバックが例外で失敗した場合に、get(Object, Callable) からスローされるラッパー例外。
    static interface
    キャッシュ値を表す(ラッパー)オブジェクト。
  • メソッドのサマリー

    修飾子と型
    メソッド
    説明
    void
    すべてのマッピングを削除してキャッシュをクリアします。
    void
    このキーが存在する場合、このキャッシュからこのキーのマッピングを削除します。
    default boolean
    このキーが存在する場合は、このキーのマッピングを削除し、以降の検索ではキーがすぐに見えないことを期待します。
    このキャッシュが指定されたキーをマップする値を返します。
    <T> T
    get(ObjectSE key, ClassSE<T> type)
    このキャッシュが指定されたキーをマップする値を返します。一般的に、戻り値がキャストされる型を指定します。
    <T> T
    get(ObjectSE key, CallableSE<T> valueLoader)
    このキャッシュが指定されたキーをマップする値を返し、必要に応じて valueLoader からその値を取得します。
    キャッシュ名を返します。
    基になるネイティブキャッシュプロバイダーを返します。
    default boolean
    すべてのマッピングを削除してキャッシュを無効にし、以降のルックアップではすべてのエントリがすぐに表示されないようにします。
    void
    put(ObjectSE key, ObjectSE value)
    指定された値をこのキャッシュ内の指定されたキーに関連付けます。
    指定された値が設定されていない場合、指定された値をこのキャッシュ内の指定されたキーと原子的に関連付けます。
  • メソッドの詳細

    • getName

      StringSE getName()
      キャッシュ名を返します。
    • getNativeCache

      ObjectSE getNativeCache()
      基になるネイティブキャッシュプロバイダーを返します。
    • get

      このキャッシュが指定されたキーをマップする値を返します。

      キャッシュにこのキーのマッピングが含まれていない場合は、null を返します。そうでない場合、キャッシュされた値(null 自体である可能性があります)が Cache.ValueWrapper で返されます。

      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      このキャッシュが指定されたキーをマップする値。Cache.ValueWrapper 内に含まれ、キャッシュされた null 値も保持する場合があります。返されるストレート null は、キャッシュにこのキーのマッピングが含まれていないことを意味します。
      関連事項:
    • get

      @Nullable <T> T get(ObjectSE key, @Nullable ClassSE<T> type)
      このキャッシュが指定されたキーをマップする値を返します。一般的に、戻り値がキャストされる型を指定します。

      メモ: この get のバリアントでは、キャッシュされた null 値とキャッシュエントリがまったく見つからないことを区別できません。代わりに、その目的のために標準の get(Object) バリアントを使用してください。

      パラメーター:
      key - 関連する値が返されるキー
      type - 戻り値の必要な型 (型チェックをバイパスする null の場合があります。キャッシュで null 値が見つかった場合、指定された型は無関係です)
      戻り値:
      このキャッシュが指定されたキー(null 自体である場合があります)をマップする値、またはキャッシュにこのキーのマッピングが含まれていない場合は null 
      例外:
      IllegalStateExceptionSE - キャッシュエントリが見つかったが、指定された型と一致しなかった場合
      導入:
      4.0
      関連事項:
    • get

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

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

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

      パラメーター:
      key - 関連する値が返されるキー
      戻り値:
      このキャッシュが指定されたキーをマップする値
      例外:
      Cache.ValueRetrievalException - valueLoader が例外をスローした場合
      導入:
      4.3
      関連事項:
    • put

      void put(ObjectSE key, @Nullable ObjectSE value)
      指定された値をこのキャッシュ内の指定されたキーに関連付けます。

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

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

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

      @Nullable default Cache.ValueWrapper putIfAbsent(ObjectSE key, @Nullable ObjectSE value)
      指定された値が設定されていない場合、指定された値をこのキャッシュ内の指定されたキーと原子的に関連付けます。

      これは次と同等です:

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

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

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

      void evict(ObjectSE key)
      このキーが存在する場合、このキャッシュからこのキーのマッピングを削除します。

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

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

      default boolean evictIfPresent(ObjectSE key)
      このキーが存在する場合は、このキーのマッピングを削除し、以降の検索ではキーがすぐに見えないことを期待します。

      デフォルトの実装は evict(Object) に委譲し、未決定のキーの存在について false を返します。キャッシュプロバイダー、特にキャッシュデコレーターは、可能な場合は直ちにエビクションを実行し(たとえば、トランザクション内で一般的にキャッシュ操作を遅延させる場合)、指定されたキーの事前の存在を確実に判断することをお勧めします。

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

      void clear()
      すべてのマッピングを削除してキャッシュをクリアします。

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

      関連事項:
    • invalidate

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