gpt4 book ai didi

Scala 数组映射返回 ArraySeq

转载 作者:行者123 更新时间:2023-12-04 11:55:56 25 4
gpt4 key购买 nike

为什么我在下面的工厂方法中不能有类型参数?

import org.junit.runner.RunWith
import org.scalatest.junit.JUnitRunner
import org.scalatest.FunSuite

@RunWith(classOf[JUnitRunner])
class WhyScalaNeverWillMakeIt extends FunSuite {

test("Array becomes ArraySeq when you least want it") {
val arr = Array("A", "B", "C")
def f: String => Dummy = new Dummy(_)

val bucket = new Bucket[Dummy](arr.map(f))
// val bucket2 = Bucket[String, Dummy](arr, f)
// val bucket3 = Bucket[Dummy](arr, f)
val bucket4 = Bucket(arr, f)
}

class Bucket[T]( val arr: Array[T] ) {/* Loads of business logic */}

object Bucket {
// def apply[T, U](arr: Array[T], f:T=>U):Bucket[U] = new Bucket[U](arr.map( b => f(b) ))
// def apply[T](arr: Array[String], f:String=>T):Bucket[T] = new Bucket[T](arr.map( b => f(b) ))
def apply(arr: Array[String], f:String=>Dummy):Bucket[Dummy] = new Bucket[Dummy](arr.map(f))
}


class Dummy(val name: String)
}

如果我取消注释 object Bucket 中的工厂方法我得到:
error: type mismatch;
found : scala.collection.mutable.ArraySeq[T]
required: Array[T]
def apply[T](arr: Array[String], f:String=>T):Bucket[T] = new Bucket[T](arr.map( b => f(b) ))

当我引入类型参数 T 时,Scala 编译器不知何故感到困惑(或者是我?;-))。也许我在这里做错了什么,但我不明白为什么引入类型参数意味着 map 函数应该将返回类型从 Array[T] 更改为 ArraySeq[T]。

我知道 Array 只是 Java Array 的包装器,我可能应该使用更花哨的 Scala 类之一,例如 Seq 或 List,但这仍然不能解释这种相当奇怪的行为。

有人可以解释为什么会发生这种情况,也许还有如何解决它(仍然使用数组)?

编辑:我正在使用 scala 2.9.1

最佳答案

只需添加 ClassManifest上下文绑定(bind):

    def apply[T, U: ClassManifest](arr: Array[T], f: T => U): Bucket[U] = new Bucket[U](arr.map(b => f(b)))
def apply[T: ClassManifest](arr: Array[String], f: String => T): Bucket[T] = new Bucket[T](arr.map(b => f(b)))

详情请查看 thisthis

关于Scala 数组映射返回 ArraySeq,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12837799/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com