一尘不染

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

java

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

尤其要考虑一些琐碎的私有方法,这些方法可以一起修改两个对象(一前一后),在这种情况下,作为返回的类型化对象听起来过于杀伤力。


阅读 236

收藏
2020-09-08

共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.util.Map.Entry,因为是java.util.AbstractMap.SimpleEntry用Java
6也有一些人现在使用共享Lang3的支持,对(2元组)

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

出于纯粹的教育原因,您可能希望了解其他语言如何做到这一点

更新:对于Java 8

Java
8将(可能是(这里是我的电话号码……给我打电话))支持一个接口java.lang.BiValue,该接口带有一个具体的实现,您可以使用named来使用java.lang.BiVal。这些类是为了帮助支持新的lambda功能。但是请注意,这仅适用于2元组。

更新:2015年

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

更新:作者2015年

如果您仍然想要元组支持,那么有三个库很好地支持元组:

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