为什么没有一个(标准的、经过 Java 认证的)解决方案作为 Java 语言本身的一部分,从 Java 方法返回多个值,而不是开发人员必须使用自己的方法,例如映射、列表、对等?为什么Java不支持n元组对象?
特别是考虑可能一起(串联)修改两个对象的简单私有(private)方法,在这种情况下,将类型化对象作为返回听起来有些过分。
最佳答案
我假设OP的意思是“为什么Java不支持n元组对象?”。 Python、Haskell、Lisp、ML 等具有异构 n 元组功能。通常,在一种语言中明显返回多个对象的能力是语法糖(即在 python 中返回 'a','b')。
原因当然是语言设计和一致性。 Java 更喜欢非常明确,不喜欢匿名数据结构(尽管我希望我们有匿名闭包)。
例如,在 Java 中,没有办法说我想要一个接受这些类型参数并返回它的回调。有些人认为这是一个巨大的弱点,其他人则喜欢一致性和明确性。
恕我直言,虽然这很烦人,但我经常通过创建静态内联类来解决这个问题:
private static class Combo {
String name;
int weight;
}
是的,这很乏味,但后来我经常重用和重构这些类,使它们成为顶级并添加行为。事实上,走这条路的优点之一是,添加新字段要容易得多,其中匿名数据结构(如 FP 语言)添加字段变得更加困难(最终会更改大量代码)。
我应该注意到,对于 2 元组,有些人使用(或滥用)java.util.Map.Entry
因为有一个java.util.AbstractMap.SimpleEntry
在Java 6中。另外有些人现在使用Commons Lang3's Pair support (2-tuple) .
Scala 通过某种作弊方式提供 n 元组支持,并拥有一大堆 2-16 元组接口(interface),这些接口(interface)是该语言的标准,并且在语法上对程序员隐藏。
出于纯粹的教育原因,您可能想看看其他的 languages accomplish this .
更新:适用于 Java 8
Java 8 将会/也许(所以这是我的号码...也许调用我)支持一个名为 java.lang.BiValue
的接口(interface)您可以使用名为 java.lang.BiVal
的具体实现。这些类旨在帮助支持新的 lambda 功能。但请注意,这仅适用于 2 元组。
更新:2015 年
Java 8没有获得对元组的支持。
更新:来自作者 2015
如果您仍然需要元组支持,可以使用三个库来很好地支持元组:
- javatuples - 支持 JDK 5 及以上版本。最多 10 元组。
- JOOλ - 来自 jOOQ 作者但需要 JDK 8。
- Commons Lang 3 - 现在支持 Triple(3 元组)并支持 JDK 6 及更高版本。
关于java - 从 Java 方法返回多个值 : why no n-tuple objects?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57548034/