Java8新特性O(shè)ptional常用方法
前言
optional 是Java8 util包中的類,我們?yōu)榱吮苊饪罩羔槷惓?NullPointerException),經(jīng)常要寫好多類似if(a!=null){...},optional就是為了解決這些問(wèn)題,讓代碼看起來(lái)更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
(此處沒(méi)有 執(zhí)行)
d=我不是空
private static String get(String s) {
System.out.println(s + ":我執(zhí)行了");
return s;
}可以看到,當(dāng)參數(shù)不為空時(shí),orElseGet中的方法是沒(méi)有執(zhí)行的。
(四)Optional.ofNullable(e).filter()
filter個(gè)方法通過(guò)傳入的定條件對(duì)Optional實(shí)例的值進(jìn)行過(guò)濾,它可以配合著.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 "李四";});
用法說(shuō)明: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ì)象都可能是空,最后的代碼看起來(lái)就像這樣。
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:
.查詢用戶信息,如果沒(méi)有則新建用戶,并將新建的用戶信息返回
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ì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02
springboot2.0整合logback日志的詳細(xì)代碼
這篇文章主要介紹了springboot2.0整合logback日志的應(yīng)用場(chǎng)景分析,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
logback-spring.xml的配置及示例詳解(直接復(fù)制粘貼可用)
在使用logback作為日志框架時(shí),可以創(chuàng)建一個(gè)名為logback-spring.xml的配置文件來(lái)自定義日志輸出的格式和方式,下面這篇文章主要給大家介紹了關(guān)于logback-spring.xml的配置及示例詳解的相關(guān)資料,文中的代碼直接復(fù)制粘貼可用,需要的朋友可以參考下2024-01-01
Maven倉(cāng)庫(kù)加載順序的實(shí)例解析
Maven倉(cāng)庫(kù)一般分為本地倉(cāng)庫(kù)和遠(yuǎn)程倉(cāng)庫(kù)。那么在實(shí)際開發(fā)中,在配置了多個(gè)倉(cāng)庫(kù)的情況下,他們之間的加載訪問(wèn)順序是怎么樣的呢,本文就詳細(xì)的來(lái)介紹一下2021-12-12

