Java8新特性O(shè)ptional常用方法
前言
optional 是Java8 util包中的類,我們?yōu)榱吮苊饪罩羔槷惓?NullPointerException),經(jīng)常要寫好多類似if(a!=null){...},optional就是為了解決這些問題,讓代碼看起來更nb。
(一)Optional.ofNullable(e).ifPresent()
此方法是當(dāng)傳入的對(duì)象為不為空(e!=null)時(shí),才會(huì)執(zhí)行ifPresent()中的代碼,e==null時(shí)什么都不會(huì)執(zhí)行,也不會(huì)拋異常。
//空對(duì)象 不會(huì)執(zhí)行 Optional.ofNullable(null).ifPresent(e -> { System.out.println("空"); }); //空字符串時(shí)會(huì)執(zhí)行 Optional.ofNullable("").ifPresent(e -> { System.out.println("空字符串"); }); //空格 也會(huì)執(zhí)行 Optional.ofNullable(" ").ifPresent(e -> { System.out.println("空格"); });
輸出:
空字符串
空格
(二)Optional.ofNullable(e).orElse()
orElse()方法,當(dāng) Optional 中有值則將其返回,為空時(shí)返回 orElse 方法傳入的參數(shù)。
此方法可以替代三目運(yùn)算符使用。
//為空時(shí)返回orElse中的值 System.out.println(Optional.ofNullable(null).orElse("默認(rèn)值")); //輸出 默認(rèn)值 //不為空時(shí) System.out.println(Optional.ofNullable("我不是空").orElse("默認(rèn)值")); //輸出 我不是空
(三)Optional.ofNullable(e).orElseGet()
orElseGet方法,當(dāng)Optional 中值為空時(shí),orElseGet與orElse效果是一樣的。當(dāng)Optional 中有值時(shí),兩者才有區(qū)別,上代碼。
//當(dāng)參數(shù)為空時(shí) String a = (String) Optional.ofNullable(null).orElse(get("a")); System.out.println("a="+a); String b = (String) Optional.ofNullable(null).orElseGet(() -> get("b")); System.out.println("b="+b); 輸出 a:我執(zhí)行了 a=a b:我執(zhí)行了 b=b //參數(shù)不為空是 String c = Optional.ofNullable("notnull").orElse(get("c")); System.out.println("c="+c); String d = Optional.ofNullable("我不是空").orElseGet(() -> get("d")); System.out.println("d="+d); 輸出 c:我執(zhí)行了 c=notnull (此處沒有 執(zhí)行) d=我不是空 private static String get(String s) { System.out.println(s + ":我執(zhí)行了"); return s; }
可以看到,當(dāng)參數(shù)不為空時(shí),orElseGet中的方法是沒有執(zhí)行的。
(四)Optional.ofNullable(e).filter()
filter個(gè)方法通過傳入的定條件對(duì)Optional實(shí)例的值進(jìn)行過濾,它可以配合著.ifPresent()方法和.orElse()使用
Optional.ofNullable("notnull").filter(t -> "notnull".equals(t)).ifPresent(t2 -> System.out.println("成立時(shí)我才會(huì)執(zhí)行")); 輸出 成立時(shí)我才會(huì)執(zhí)行 String a=Optional.ofNullable("notnull").filter(t -> "null".equals(t)).orElse(("不成立時(shí)我才會(huì)執(zhí)行")); System.out.println("a="+a); String b=Optional.ofNullable("notnull").filter(t -> "notnull".equals(t)).orElse(("不成立時(shí)我才會(huì)執(zhí)行")); System.out.println("b="+b); 輸出 a=不成立時(shí)我才會(huì)執(zhí)行 b=notnull
補(bǔ)充:Optional的用法代碼案例
示例1:
String s = Optional.ofNullable(user) .map(o -> o.getUsername()) .orElseGet(() -> { return "李四";});
用法說明:Optional.ofNullable(user)是判斷user是否為null,如果為null,則不會(huì)執(zhí)行map(o -> o.getUsername()),直接執(zhí)行orElseGet(() -> { return “李四”;})方法。如果不為null,則只執(zhí)行map(o -> o.getName())方法。
還有一個(gè)跟orElseGet()類似的方法:orElse(),orElse()方法不管ofNullable()值是否為null,都會(huì)執(zhí)行orElse()的代碼,而orElseGet()方法只有在ofNullable()值為null時(shí)才會(huì)執(zhí)行傳入的函數(shù)。
示例2:
有如下代碼,需要獲得Test2中的Info信息,但是參數(shù)為Test4,我們要一層層的申請(qǐng),每一層都獲得的對(duì)象都可能是空,最后的代碼看起來就像這樣。
public String testSimple(Test4 test) { if (test == null) { return ""; } if (test.getTest3() == null) { return ""; } if (test.getTest3().getTest2() == null) { return ""; } if (test.getTest3().getTest2().getInfo() == null) { return ""; } return test.getTest3().getTest2().getInfo(); }
但是使用Optional后,整個(gè)就都不一樣了。
public String testOptional(Test test) { return Optional.ofNullable(test) .flatMap(Test::getTest3) .flatMap(Test3::getTest2) .map(Test2::getInfo) .orElse(""); }
示例3:
Optional.ofNullable(user).ifPresent(o -> o.setUsername("李四"));
如果user不為null,執(zhí)行ifPresent()方法,否則不執(zhí)行ifPresent()方法,這與orElseGet()用法剛好相反。
示例4:
.查詢用戶信息,如果沒有則新建用戶,并將新建的用戶信息返回
User user = Optional.ofNullable( baseMapper.selectOne( new QueryWrapper<User>() .lambda() .eq(User::getAlipayUserId, result.getUserId()) .eq(User::getDelFlag, false) )).orElseGet(()-> { User newUser = User.builder() .relation(User.Relation.Unrelated) .authentication(false) .status(User.Status.Normal) .updateUserId(User.DEFAULT_USER_ID) .createUserId(User.DEFAULT_USER_ID) .roles(User.ROLE_USER_INFO) .alipayUserId(alipayUserId) .build(); this.save(newUser); return newUser; });
示:5:
Optional.ofNullable( baseMapper.selectOne(new QueryWrapper<User>().lambda().eq(User::getMobileNumber, phone)) ).filter(user -> { if (StringUtils.isNotBlank(user.getAlipayUserId()) && user.getAlipayUserId().equals(userId)) { return true; } baseMapper.physicalDeleteByUserId(userId); baseMapper.update(new User(), new UpdateWrapper<User>().lambda() .set(User::getAlipayUserId, userId) .set(User::getUpdateTime, LocalDateTime.now()) .eq(User::getMobileNumber, phone)); return true; }).orElseGet(() -> { baseMapper.update(new User(), new UpdateWrapper<User>().lambda() .set(User::getMobileNumber, phone) .set(User::getUpdateTime, LocalDateTime.now()) .eq(User::getAlipayUserId, userId)); return null; });
filter()方法的用法:只有Optional.ofNullable()不為空時(shí),才會(huì)執(zhí)行filter()方法,否則會(huì)直接執(zhí)行orElseGet()方法。當(dāng)執(zhí)行filter()方法時(shí),如果方法內(nèi)返回true,則直接將Optional.ofNullable()的對(duì)象返回,如果方法內(nèi)返回false,則繼續(xù)執(zhí)行orElseGet()方法。
總結(jié)
到此這篇關(guān)于Java8新特性O(shè)ptional常用方法的文章就介紹到這了,更多相關(guān)Optional常用方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 實(shí)現(xiàn)下壓棧的操作(能動(dòng)態(tài)調(diào)整數(shù)組大小)
這篇文章主要介紹了java 實(shí)現(xiàn)下壓棧的操作(能動(dòng)態(tài)調(diào)整數(shù)組大小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02springboot2.0整合logback日志的詳細(xì)代碼
這篇文章主要介紹了springboot2.0整合logback日志的應(yīng)用場(chǎng)景分析,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02logback-spring.xml的配置及示例詳解(直接復(fù)制粘貼可用)
在使用logback作為日志框架時(shí),可以創(chuàng)建一個(gè)名為logback-spring.xml的配置文件來自定義日志輸出的格式和方式,下面這篇文章主要給大家介紹了關(guān)于logback-spring.xml的配置及示例詳解的相關(guān)資料,文中的代碼直接復(fù)制粘貼可用,需要的朋友可以參考下2024-01-01Maven倉(cāng)庫(kù)加載順序的實(shí)例解析
Maven倉(cāng)庫(kù)一般分為本地倉(cāng)庫(kù)和遠(yuǎn)程倉(cāng)庫(kù)。那么在實(shí)際開發(fā)中,在配置了多個(gè)倉(cāng)庫(kù)的情況下,他們之間的加載訪問順序是怎么樣的呢,本文就詳細(xì)的來介紹一下2021-12-12