标签:java java-8 nullable optional
考虑这个表达式的用法:
String hi = Optional.ofNullable(sayHi()).orElse("-");
这有效地对应于这个三元表达式:
String hi = sayHi() != null ? sayHi() : "-";
使用Optional.ofNullable和方法调用是一种好习惯吗?或者只是额外的详细编码?
我认识到Optional.ofNullable实际上创建了一个变量,并避免两次调用sayHi()方法.为了避免这个问题,你实际上可以创建一个额外的变量,但这会增加三元选项的详细程度:
String hi = sayHi();
hi = hi != null ? hi : "-";
另一方面,Optional.ofNullable在hi不是null的情况下创建一个额外的Optional对象.所以肯定会有更多的开销.
因此,使用这种类型的构造来替换三元构造函数似乎有一些利弊.
顺便说一下:这是Optional.ofNullable的Java 8实现:
public static <T> Optional<T> ofNullable(T value) {
return value == null ? empty() : of(value);
}
解决方法:
每当我想到为特定目的使用Optional API时,我总是提醒自己它打算做什么以及为什么它被带入JDK,即
Optional in intended to provide a limited mechanism for library method
return types where there is a clear need to represent “no result” and
where using null for this is overwhelmingly likely to cause errors – Stuart Marks
可选主要关注可能有也可能没有返回值的返回类型.
过度使用此构造就像在您的这个特定示例中一样,只会导致额外的内存分配和GC开销.
我会保持简单,而是:
String hi = sayHi();
if(hi == null) hi = “-“;
...
标签:java,java-8,nullable,optional 来源: https://codeday.me/bug/20190930/1837220.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。