12

我想实现可以任意Seq[T]返回Seq[T]的方法。但是当String提供时它也应该返回String

由于从to的一些隐式转换而传递String作品,但我得到了回报。有可能回来吗?StringWrappedString extends IndexedSeq[Char]Seq[Char]String

val sx: Seq[Int] = firstAndLast(List(1, 2, 3, 4))
val s1: Seq[Char] = firstAndLast("Foo Bar")
val s2: String = firstAndLast("Foo Bar")  //incompatible types error

def firstAndLast[T](seq: Seq[T]) = Seq(seq.head, seq.last)

firstAndLast()实现无关紧要,这只是一个例子。

4

1 回答 1

15

对的,这是可能的。您必须要求其中一个花哨CanBuildFrom的 s:

import scala.collection.generic.CanBuildFrom

def firstAndLast[CC, A, That](seq: CC)(implicit asSeq: CC => Seq[A], cbf: CanBuildFrom[CC, A, That]): That = {
  val b = cbf(seq)
  b.sizeHint(2)
  b += seq.head
  b += seq.last
  b.result
}

这也适用于数组。奖励:示例中的所有行都将按预期编译和工作。

于 2012-05-21T16:59:13.920 回答