java.lang.Object
java.util.OptionalInt
public final class OptionalInt extends Object
int値を含む場合と含まない場合があるコンテナ・オブジェクトです。 値が存在する場合、isPresent()はtrueを返します。 値が存在しない場合、オブジェクトはemptyとみなされ、isPresent()はfalseを返します。 
 orElse() (値がない場合はデフォルト値を返します)およびifPresent() (値が存在する場合にアクションを実行)のような、含まれた値の有無に依存する追加のメソッドが提供されています。
 
これはvalue-basedクラスです。プログラマは、equalのインスタンスを交換可能として扱い、同期にインスタンスを使用しないようにする必要があります。そうしないと、予期しない動作が発生する可能性があります。 たとえば、将来のリリースでは、同期が失敗する可能性があります。
- APIのノート:
- OptionalIntは、主に"検索なし"を明示的に必要とするメソッドの戻り型として使用することを意図しています 型が- OptionalIntの変数は、それ自体決して- nullであってはなりません。常に- OptionalIntインスタンスを指す必要があります。
- 導入されたバージョン:
- 1.8
- 
メソッドのサマリー修飾子と型メソッド説明static OptionalIntempty()空のOptionalIntインスタンスを返します。boolean他のオブジェクトがこのOptionalIntに"に等しい"かどうかを示します。intgetAsInt()値がある場合は値を返し、そうでない場合はNoSuchElementExceptionをスローします。inthashCode()存在する場合は値のハッシュ・コードを返し、値が存在しない場合は0(zero)を返します。voidifPresent(IntConsumer action) 値が存在する場合は、その値で指定されたアクションを実行し、そうでない場合は何もしません。voidifPresentOrElse(IntConsumer action, Runnable emptyAction) 値が存在する場合は、指定されたアクションを値とともに実行し、そうでない場合は空のベースのアクションを実行します。booleanisEmpty()値が存在しない場合はtrue、それ以外の場合falseを返します。boolean値が存在する場合はtrueを返し、そうでない場合はfalseを返します。static OptionalIntof(int value) 指定された値を記述するOptionalIntを返します。intorElse(int other) 値が存在する場合は値を返し、そうでない場合はotherを返します。intorElseGet(IntSupplier supplier) 値が存在する場合は値を返し、そうでない場合は供給関数によって生成された結果を返します。int値がある場合は値を返し、そうでない場合はNoSuchElementExceptionをスローします。<X extends Throwable>
 intorElseThrow(Supplier<? extends X> exceptionSupplier) 値が存在する場合は値を返し、そうでない場合は例外を提供する関数によって生成された例外をスローします。stream()値が存在する場合は、その値のみを含む順次IntStreamを返し、それ以外の場合は空のIntStreamを返します。toString()デバッグに適したこのOptionalIntの空でない文字列表現を返します。
- 
メソッドの詳細- 
emptypublic static OptionalInt empty()空のOptionalIntインスタンスを返します。 このOptionalIntには値はありません。- APIのノート:
- これは一時的なものですが、OptionalInt.empty()によって返されたインスタンスと==または!=を比較して、オブジェクトが空であるかどうかをテストしないでください。 シングルトンである保証はありません。 かわりに、isEmpty()またはisPresent()を使用してください。
- 戻り値:
- 空のOptionalInt。
 
- 
ofpublic static OptionalInt of(int value) 指定された値を記述するOptionalIntを返します。- パラメータ:
- value- 説明する値
- 戻り値:
- 値が存在するOptionalInt
 
- 
getAsIntpublic int getAsInt()値がある場合は値を返し、そうでない場合はNoSuchElementExceptionをスローします。- APIのノート:
- このメソッドの好ましい代替メソッドはorElseThrow()です。
- 戻り値:
- このOptionalIntで記述された値
- 例外:
- NoSuchElementException- 値が存在しない場合
 
- 
isPresentpublic boolean isPresent()値が存在する場合はtrueを返し、そうでない場合はfalseを返します。- 戻り値:
- 値が存在する場合はtrue、そうでない場合はfalse
 
- 
isEmptypublic boolean isEmpty()値が存在しない場合はtrue、それ以外の場合falseを返します。- 戻り値:
- 値が存在しない場合はtrue、それ以外の場合はfalse
- 導入されたバージョン:
- 11
 
- 
ifPresentpublic void ifPresent(IntConsumer action) 値が存在する場合は、その値で指定されたアクションを実行し、そうでない場合は何もしません。- パラメータ:
- action- 値が存在する場合、実行されるアクション
- 例外:
- NullPointerException- 値が存在し、与えられたアクションが- nullの場合
 
- 
ifPresentOrElsepublic void ifPresentOrElse(IntConsumer action, Runnable emptyAction) 値が存在する場合は、指定されたアクションを値とともに実行し、そうでない場合は空のベースのアクションを実行します。- パラメータ:
- action- 値が存在する場合、実行されるアクション
- emptyAction- 値が存在しない場合、実行される空のベースのアクション
- 例外:
- NullPointerException- 値が存在し、指定されたアクションが- nullの場合、または値が存在しない場合、指定された空のアクションは- nullです。
- 導入されたバージョン:
- 9
 
- 
streampublic IntStream stream()値が存在する場合は、その値のみを含む順次IntStreamを返し、それ以外の場合は空のIntStreamを返します。- APIのノート:
- このメソッドを使用して、オプションの整数のStreamを現在の整数のIntStreamに変換できます:Stream<OptionalInt> os = .. IntStream s = os.flatMapToInt(OptionalInt::stream)
- 戻り値:
- IntStreamとしてのオプションの値
- 導入されたバージョン:
- 9
 
- 
orElsepublic int orElse(int other) 値が存在する場合は値を返し、そうでない場合はotherを返します。- パラメータ:
- other- 値が存在しない場合、返される値
- 戻り値:
- 値(存在する場合)、それ以外の場合はother
 
- 
orElseGetpublic int orElseGet(IntSupplier supplier) 値が存在する場合は値を返し、そうでない場合は供給関数によって生成された結果を返します。- パラメータ:
- supplier- 戻される値を生成する供給関数
- 戻り値:
- 存在する場合は値、そうでない場合は供給関数によって生成された結果
- 例外:
- NullPointerException- 値が存在せず、供給関数が- nullの場合
 
- 
orElseThrowpublic int orElseThrow()値がある場合は値を返し、そうでない場合はNoSuchElementExceptionをスローします。- 戻り値:
- このOptionalIntで記述された値
- 例外:
- NoSuchElementException- 値が存在しない場合
- 導入されたバージョン:
- 10
 
- 
orElseThrow値が存在する場合は値を返し、そうでない場合は例外を提供する関数によって生成された例外をスローします。- APIのノート:
- 引数リストが空である例外コンストラクタへのメソッド参照をサプライヤとして使用できます。 たとえば、IllegalStateException::newなどです。
- 型パラメータ:
- X- スローされる例外の型
- パラメータ:
- exceptionSupplier- スローされる例外を生成する供給関数
- 戻り値:
- 存在する場合は値
- 例外:
- X- 値が存在しない場合
- NullPointerException- 値が存在せず、例外を提供する関数が- nullの場合
 
- 
equalspublic boolean equals(Object obj) 他のオブジェクトがこのOptionalIntに"に等しい"かどうかを示します。 他方のオブジェクトは次の場合に同等と見なされます。- それもOptionalIntである、および
- 両方のインスタンスに存在する値がない、または
- 存在する値が==によってお互いに等しい。
 
- それも
- 
hashCodepublic int hashCode()存在する場合は値のハッシュ・コードを返し、値が存在しない場合は0(zero)を返します。
- 
toStringpublic String toString()デバッグに適したこのOptionalIntの空でない文字列表現を返します。 正確な表示フォーマットは未指定であり、実装とバージョンの間で異なることがあります。
 
-