Scala:使用泛型收集

Bru*_*uno 3 generics scala partialfunction

考虑到以下场景

val items = List("a", "b", "c", 1, 2, 3, false, true)
def intItems = items.collect {case i : Int => i}
def stringItems = items.collect {case s : String => s}
Run Code Online (Sandbox Code Playgroud)

有没有办法创建一个通用函数来处理这种行为?

我尝试了以下方法

def itemsAs[T]: List[T] = items.collect { case item: T => item } 
Run Code Online (Sandbox Code Playgroud)

itemsAs[Int] 
Run Code Online (Sandbox Code Playgroud)

回报

List[Int]] = List(a, b, c, 1, 2, 3, false, true)
Run Code Online (Sandbox Code Playgroud)

另一种方法是提供partial functionas 参数,但仍然必须复制case i: Int => iand case s: String => s。有没有办法让它变得更紧凑?谢谢

dve*_*eim 5

val items = List("a", "b", "c", 1, 2, 3, false, true)
import scala.reflect.ClassTag
def collect[T: ClassTag] = items.collect { case x: T => x }
collect[Int] // List(1, 2, 3)
collect[String] // List(a, b, c)
Run Code Online (Sandbox Code Playgroud)

有关更多详细信息,请参阅http://docs.scala-lang.org/overviews/reflection/typetags-manifests.html 。