public final class OptionalInt extends Object
int
值的容器对象。
如果值存在, isPresent()
将返回true
和getAsInt()
将返回值。
提供依赖于包含值的存在或不存在的附加方法,例如orElse()
(如果值不存在则返回默认值)和ifPresent()
(如果值存在则执行代码块)。
这是一个value-based类; 使用身份敏感的操作(包括引用相等(的==
上的实例),标识哈希码,或同步) OptionalInt
可具有不可预测的结果,应当避免。
Modifier and Type | Method and Description |
---|---|
static OptionalInt |
empty()
返回一个空的
OptionalInt 实例。
|
boolean |
equals(Object obj)
指示某个其他对象是否等于此OptionalInt。
|
int |
getAsInt()
如果
OptionalInt 中存在值,则返回值,否则抛出
NoSuchElementException 。
|
int |
hashCode()
返回当前值的哈希码值(如果有的话),如果没有值,则返回0(零)。
|
void |
ifPresent(IntConsumer consumer)
让指定的消费者接受该值,如果一个值存在,否则什么也不做。
|
boolean |
isPresent()
如果有值存在,返回
true ,否则
false 。
|
static OptionalInt |
of(int value)
返回一个
OptionalInt 具有指定值存在。
|
int |
orElse(int other)
返回值如果存在,否则返回
other 。
|
int |
orElseGet(IntSupplier other)
返回值(如果存在),否则调用
other 并返回该调用的结果。
|
<X extends Throwable> |
orElseThrow(Supplier<X> exceptionSupplier)
返回包含的值(如果存在),否则抛出由提供的供应商创建的异常。
|
String |
toString()
返回对象的字符串表示形式。
|
public static OptionalInt empty()
OptionalInt
实例。
此OptionalInt没有值。
==
与Option.empty()返回的Option.empty()
进行比较,则避免测试对象是否为空。
不能保证是单身人士。
相反,请使用isPresent()
。
OptionalInt
public static OptionalInt of(int value)
OptionalInt
具有指定值存在。
value
- 要存在的值
OptionalInt
与值存在
public int getAsInt()
OptionalInt
中存在值,则返回值,否则抛出
NoSuchElementException
。
OptionalInt
NoSuchElementException
- 如果没有值
isPresent()
public boolean isPresent()
true
如果有值存在,否则
false
。
true
如果存在值,否则为
false
public void ifPresent(IntConsumer consumer)
consumer
- 如果存在值,则执行块
NullPointerException
- 如果值存在且
consumer
为空
public int orElse(int other)
other
。
other
- 如果没有值存在,返回的值
other
public int orElseGet(IntSupplier other)
other
并返回该调用的结果。
other
- 一个
IntSupplier
,如果没有值,则返回其结果
other.getAsInt()
NullPointerException
- 如果值不存在,并且
other
为空
public <X extends Throwable> int orElseThrow(Supplier<X> exceptionSupplier) throws X extends Throwable
IllegalStateException::new
X
- 要抛出的异常的类型
exceptionSupplier
- 将返回被抛出的异常的供应商
X
- 如果没有值存在
NullPointerException
- 如果没有值,
exceptionSupplier
为空
X extends Throwable
public boolean equals(Object obj)
OptionalInt
和; ==
彼此“相等”。 equals
在类别
Object
obj
- 要进行平等检验的对象
false
Object.hashCode()
, HashMap
public int hashCode()
hashCode
在
Object
Object.equals(java.lang.Object)
,
System.identityHashCode(java.lang.Object)
public String toString()
toString
方法返回一个“textually代表”这个对象的字符串。
结果应该是一个简明扼要的表达,容易让人阅读。
建议所有子类覆盖此方法。
该toString
类方法Object
返回一个由其中的对象是一个实例,该符号字符`的类的名称的字符串@
”和对象的哈希码的无符号的十六进制表示。 换句话说,这个方法返回一个等于下列值的字符串:
返回适用于调试的此对象的非空字符串表示形式。 准确的表示格式是未指定的,可能会在实现和版本之间变化。getClass().getName() + '@' + Integer.toHexString(hashCode())