java – 为什么list.sort不使用Optional API

前端之家收集整理的这篇文章主要介绍了java – 为什么list.sort不使用Optional API前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Java 8在List接口上引入了一个新的默认方法来对其进行排序.它的签名是:
void sort(Comparator<? super E> c)

文件说:

If the specified comparator is null then all elements in this list
must implement the Comparable interface and the elements’ natural
ordering should be used.

因此,如果您想按照它的自然顺序对列表进行排序(并且您的元素具有可比性),则必须执行list.sort(null);这有点奇怪我的意见.

如果他们使用了Optional,那么doc会说你可以选择提供一个比较器,如果没有提供,它会认为这些元素已经具有可比性.

list.sort(null); call将被转换为list.sort(Optional.empty());.

因为它是一种暴露于外部世界的方法,我会发现它更准确.

他们为什么不使用新的Optional API呢?

解决方法

可选用作返回类型.这一直是JDK-8开发人员的口头禅.因此,他们不会通过使用它作为论据来打破自己的规则.

也就是说,我会强制论证,从而迫使开发人员使用

list.sort(Comparator.<Foo>naturalOrder());

即使我可以传递null,我发现上面的内容更具可读性,而且更加冗长.这就是我在代码中使用的内容.

原文链接:https://www.f2er.com/java/127320.html

猜你在找的Java相关文章