动机
这个问题是关于使用Scala中的数据列表,以及使用元组或类对象来保存数据。也许我的一些假设是错误的,所以就这样了。
我现在的方法
据我所知,元组不允许在提供的._1、._2等之外优雅地处理它们的元素。我可以使用它们,但是只要从定义它的代码行中提取数据,代码就会有些不愉快。
而且,正如我所理解的,Scala Map只能对其值使用单个类型声明,因此除了类型继承的情况外,它不能对其值的值类型进行多样化。(关于后一点,考虑使用Map值的类型层次结构“多样性”-除非类层次结构首先适合任何“模型”直觉,否则可能是非常人为的)。
因此,当我需要列出每个元素包含两个或多个命名数据实体的列表时(例如,在String类型和List类型中的一个下面),每个元素都可以通过一个可理解的名称访问,我求助于:
case class Foo (name1: String, name2: List[String])
val foos: List[Foo] = ...然后,我可以使用.name1和.name2访问列表的实例。
我在这里看到的缺点和问题
当列表非常大时,我是否应该假设这比使用元组作为列表的类型要低性能或占用更多的内存?或者,在Scala中是否有一种实现结构语义的不同优雅的方法?
发布于 2014-09-27 15:32:49
就性能而言,我不认为元组和cases类的实例之间会有任何区别。事实上,一个元组 an instance of a case class。
其次,如果您正在寻找另一种更易读的方法来从元组中获取数据,我建议您考虑模式匹配:
val (name1, name2) = ("first", List("second", "third"))https://stackoverflow.com/questions/26075853
复制相似问题