4 回答

TA貢獻(xiàn)1875條經(jīng)驗(yàn) 獲得超3個(gè)贊
你可以這樣做:
Integer total = Optional.of(new Integer(10)).orElse(null);
如果該Optional
值可以為空,則:
Integer total = Optional.ofNullable(new Integer(10)).orElse(null);
Optional.ofNullable
在有值的情況下會(huì)防止NPEnull
。
在第一個(gè)示例中出現(xiàn)此錯(cuò)誤的原因是,在 lambda 表達(dá)式中,不允許更改局部變量的引用。這就是為什么它們需要被宣布final
或?qū)嶋H上是最終的。
第二個(gè)示例之所以有效,是因?yàn)檫@里您沒(méi)有更改total
變量的引用。您只是使用其set()
方法更新其值。

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超8個(gè)贊
在這種情況下,您不僅觀察到兩個(gè)類之間的差異,而且觀察到使用它們的方式的差異。
b.ifPresent(b -> total =b);
這嘗試將一個(gè)新的Integer
引用(對(duì)不同對(duì)象的引用)分配給b
。Integer
或AtomicInteger
任何其他類型都不允許這樣做。
b.ifPresent(b -> total.set(b));
set
這會(huì)調(diào)用現(xiàn)有對(duì)象中的方法 ( ) AtomicInteger
。Integer
以及 AtomicInteger
所有其他類都允許從 lambda 內(nèi)部調(diào)用方法。不過(guò),對(duì)于您的用例來(lái)說(shuō),一個(gè)重要的區(qū)別是,Integer
由于類是不可變的,因此沒(méi)有一種允許您更改值的方法。

TA貢獻(xiàn)1878條經(jīng)驗(yàn) 獲得超4個(gè)贊
他們的行為有所不同,因?yàn)槟阏谧鰞杉耆煌氖虑椤?/p>
在你的第一個(gè):
b.ifPresent(b -> total =b);
變量“total”代表您要更改其值的內(nèi)存區(qū)域。這是不允許的。
在第二 :
b.ifPresent(b -> total.set(b));
變量“total”表示內(nèi)存中引用(或指向)AtomicInteger 類實(shí)例的區(qū)域。您沒(méi)有更改該變量,而只是調(diào)用它的方法。由于“總計(jì)”本身沒(méi)有變化,所以這就是所謂的“有效最終”,因此是允許的。

TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超6個(gè)贊
Integer
您詢問(wèn)為什么和的行為AtomicInteger
在您的情況下有所不同。究其原因,確實(shí)無(wú)關(guān)AtomicInteger
。相反,區(qū)別在于它Integer
是不可變的,因此,更改對(duì) an 的引用的值的唯一方法Integer
是通過(guò)賦值。但 lambda 表達(dá)式不允許對(duì)表達(dá)式范圍之外的局部變量進(jìn)行賦值。
有多種方法可以在不使用的情況下解決此問(wèn)題AtomicInteger
:
創(chuàng)建您自己的
MutableInteger
,可以在 lambda 內(nèi)部設(shè)置使
Integer
對(duì)象變量而不是局部變量使用
orElse
或各種替代方法返回值而不是將其設(shè)置在內(nèi)部ifPresent
另請(qǐng)注意,您可能會(huì)考慮OptionalInt
而不是Optional<Integer>
.
添加回答
舉報(bào)