这段Java代码连不少大佬都栽了跟头,何况我

举报
码农小胖哥 发表于 2022/04/01 01:31:30 2022/04/01
【摘要】 最近用了Optional实现了一段逻辑,想不到居然翻车了。看了源码之后才恍然大悟,不过翻车的不是我一个人,很多人都说自己在这个地方翻过车,其中不乏一些大佬级的人物。 接下来看看都是怎么翻车的吧。     String  conditional =&nbs...

最近用了Optional实现了一段逻辑,想不到居然翻车了。看了源码之后才恍然大悟,不过翻车的不是我一个人,很多人都说自己在这个地方翻过车,其中不乏一些大佬级的人物。

接下来看看都是怎么翻车的吧。


   
  1.     String  conditional =  doPlanA();
  2.     if (conditional==null){ 
  3.        conditional = doPlanB();
  4.     }

这个代码片段相信大家都知道什么意思吧。doPlanA的返回值如果为null就执行doPlanB来获取conditional的值。

如果好好按照规矩写就没什么问题,可我偏偏想用Optional重写这个逻辑,我想当然地以为是这么写的:


   
  1. String  conditional = Optional.ofNullable(doPlanA())
  2.         .orElse(doPlanB());

当我执行了这段代码之后,怎么肥事?为什么当doPlanA的返回值不为nulldoPlanB也执行了?不过认真看了之后确实是自己误解了。因为这段代码其实执行的就是orElse逻辑,而ofNullable是定义初始化的逻辑,思维惯性把我带沟里了。执行orElse逻辑必然执行doPlanB获取返回值传递给该方法的形参,因此出现了逻辑上的偏差。

那么如何才能真正的达到我们想要的效果呢?Optional还提供了一个方法orElseGet:


   
  1.  public T orElseGet(Supplier<? extends T> other) {
  2.         return value != null ? value : other.get();
  3.  }

传入的是一个Supplier函数,这个函数提供了一个获取结果的方法,只有当我们需要获取结果才会根据逻辑获取结果。所以最终的正确方式是这样的:


   
  1. String  conditional = Optional.ofNullable(doPlanA())
  2.         .orElseGet(()->doPlanB());

从这个实例中我们可以发现,有时候的问题仅仅只是表象,会干扰我们的思维。很多时候我们需要突破惯性思维,对API的理解再深入些,这样才能少犯错。不知道你有没有犯过类似的错误,欢迎留言讨论。

打个赌你可能不知道如何获取Java泛型的Class对象

2021-07-01

后端Java开发如何防御XSS攻击

2021-06-30

文章来源: felord.blog.csdn.net,作者:码农小胖哥,版权归原作者所有,如需转载,请联系作者。

原文链接:felord.blog.csdn.net/article/details/118485286

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。