从Java方法返回多个值:为什么没有n元组对象?

2022-08-31 19:52:06

作为Java语言本身的一部分,为什么没有一个(标准的,Java认证的)解决方案来从Java方法返回多个值,而不是开发人员必须使用自己的方法,例如Maps,Lists,Pairs等?为什么 Java 不支持 n 元组对象?

特别是考虑琐碎的私有方法,这些方法可以一起修改两个对象(串联),在这种情况下,类型化对象作为返回听起来有些过分。


答案 1

我假设OP的意思是“为什么Java不支持n元组对象?Python,Haskell,Lisp,ML等具有异构n元组功能。通常,在一种语言中显然返回多个对象的能力是语法糖(即在python中返回“a”,“b”)。

原因当然是语言设计和一致性。Java更喜欢非常明确,不喜欢匿名数据结构(尽管我希望我们有匿名闭包)。

例如,在Java中,没有办法说我想要一个回调来获取这些类型参数并返回它。有些人认为这是一个巨大的弱点,而另一些人则喜欢一致性和明确性。

恕我直言,虽然它很烦人,但我经常通过制作静态内联类来解决这个问题:

private static class Combo {
   String name;
   int weight;
}

是的,这很乏味,但后来我经常重用和重构这些类,使它们成为顶级并添加行为。事实上,走这条路的一个优点是,添加新字段要容易得多,因为匿名数据结构(如FP语言),添加字段变得更加困难(你最终会更改大量代码)。

我应该注意的是,对于2元组,有些人使用(或滥用),因为Java 6中有一个。此外,有些人现在使用Commons Lang3的配对支持(2元组)。java.util.Map.Entryjava.util.AbstractMap.SimpleEntry

Scala通过作弊和拥有一大堆2-16元组接口来支持n元组,这些元组接口是该语言的标准,并且在语法上对程序员隐藏。

出于纯粹的教育原因,您可能想看看其他语言是如何做到这一点的

更新:用于 Java 8

Java 8会/也许(所以这是我的数字...也许可以叫我)支持一个接口,该接口具有可以使用称为.这些类用于帮助支持新的 lambda 功能。但请注意,这仅适用于 2 元组。java.lang.BiValuejava.lang.BiVal

更新:2015年

Java 8 没有获得对元组的支持。

更新:从作者2015年开始

如果您仍然希望支持元组,则有三个库可以很好地支持元组:

  • javatuples - 支持 JDK 5 及更高版本。最多 10 元组。
  • JOOλ - 来自 jOOQ 的作者,但需要 JDK 8。
  • Commons Lang 3 - 现在支持三元组(3元组),并支持JDK 6及更高版本。

答案 2

Java方法返回正好零或一个值;这是java的标准。如果需要返回多个值,请创建一个包含多个值的对象并将其返回。