Java中的Optional處理方法
在我們?nèi)粘5拈_(kāi)發(fā)中,我們經(jīng)常會(huì)遇到 NullPointerException。如何才能優(yōu)雅的處理NPE?這里告訴大家一個(gè)較為流行的方法
java.util.Optional
使用Optional來(lái)修飾對(duì)象,表示這個(gè)對(duì)象可能為null。在使用時(shí),就要加以注意,必須要考慮該值為null的場(chǎng)景。
使用Optional構(gòu)建對(duì)象
// 創(chuàng)建一個(gè)空的car Optional<Car> car = Optional.empty(); // 使用of創(chuàng)建,of的值一定不能是null,否則賦值階段就報(bào) NullPointerException /** * if (obj == null) * throw new NullPointerException(); */ Car car1 = new Car(); Optional<Car> ocar1 = Optional.of(car1); // 創(chuàng)建一個(gè)可以為null的Optional,該方法支持car為null,但是會(huì)在用到car的地方拋出異常,但不是空指針異常。 Car car2 = new Car(); Optional<Car> ocar2 = Optional.ofNullable(car2); System.out.println(ocar2.get()); Optional<Car> ocar22 = Optional.ofNullable(null);
獲取Optional中的對(duì)象
1.get: 這是最不安全的方法。如果變量存在就返回,不存在的話則會(huì)拋出NoSuchElementException的異常。所以,get()的使用場(chǎng)景一定是十分確定Optional修飾的值一定是有內(nèi)容的,否則不建議使用。
/** * public T get() { * if (value == null) { * throw new NoSuchElementException("No value present"); * } * return value; * } */ String name = car.getInsurance().get().getName(); System.out.println(name);
2.orElse: 作用和get一樣,但是沒(méi)有值時(shí)可以使用默認(rèn)值
/** * public T orElse(T other) { * return value != null ? value : other; * } */ String orName = car.getInsurance().orElse(new Insurance()).getName(); System.out.println(orName);
3.orElseGet: orElse的延時(shí)版本。只有當(dāng)val為空時(shí),才會(huì)創(chuàng)建defleat value
/** * public T orElseGet(Supplier<? extends T> supplier) { * return value != null ? value : supplier.get(); * } */ String getElseName = car.getInsurance().orElseGet(Insurance::new).getName(); System.out.println("getElseName " + getElseName);
4.orElseThrow: 和orElse類似,只是當(dāng)value不存在時(shí)拋出異常
public T orElseThrow() { if (value == null) { throw new NoSuchElementException("No value present"); } return value; }
5.ifPresent: 判斷值存在之后再操作,不存在就不操作
/** * public void ifPresent(Consumer<? super T> action) { * if (value != null) { * action.accept(value); * } * } */ car.getInsurance().ifPresent(ins -> { String pname = ins.getName(); System.out.println("inPresent " + pname); });
Optional 中map和flatmap的差別
Optional<Optional<Car>> mCar = optionalPerson.map(Person::getCar); Optional<Car> flatMapCap = optionalPerson.flatMap(Person::getCar);
map
public <U> Optional<U> map(Function<? super T, ? extends U> mapper) { Objects.requireNonNull(mapper); if (!isPresent()) { return empty(); } else { // 返回值使用Optional包裝 return Optional.ofNullable(mapper.apply(value)); } }
flatMap
public <U> Optional<U> flatMap(Function<? super T, ? extends Optional<? extends U>> mapper) { Objects.requireNonNull(mapper); if (!isPresent()) { return empty(); } else { @SuppressWarnings("unchecked") Optional<U> r = (Optional<U>) mapper.apply(value); // 返回值沒(méi)有包裝,直接是Optional對(duì)象,只做了一次判null return Objects.requireNonNull(r); } }
到此這篇關(guān)于Java中的Optional的文章就介紹到這了,更多相關(guān)Java中的Optional內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解JDK 5 Annotation 注解之@Target的用法介紹
這篇文章主要介紹了詳解JDK 5 Annotation 注解之@Target的用法介紹,需要的朋友可以參考下2016-02-02Mybatis -如何處理clob類型數(shù)據(jù)
這篇文章主要介紹了Mybatis 如何處理clob類型數(shù)據(jù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06java 如何實(shí)現(xiàn)正確的刪除集合中的元素
這篇文章主要介紹了java 如何實(shí)現(xiàn)正確的刪除集合中的元素,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09mybatis實(shí)現(xiàn)對(duì)數(shù)據(jù)的增刪查改實(shí)例詳解
這篇文章主要介紹了mybatis實(shí)現(xiàn)對(duì)數(shù)據(jù)的增刪查改實(shí)例詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07Java內(nèi)存各部分OOM出現(xiàn)原因及解決方法(必看)
下面小編就為大家?guī)?lái)一篇Java內(nèi)存各部分OOM出現(xiàn)原因及解決方法(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04springboot通過(guò)spel結(jié)合aop實(shí)現(xiàn)動(dòng)態(tài)傳參的案例
SpEl 是Spring框架中的一個(gè)利器,Spring通過(guò)SpEl能在運(yùn)行時(shí)構(gòu)建復(fù)雜表達(dá)式、存取對(duì)象屬性、對(duì)象方法調(diào)用等,今天通過(guò)本文給大家介紹springboot?spel結(jié)合aop實(shí)現(xiàn)動(dòng)態(tài)傳參,需要的朋友可以參考下2022-07-07