我怎样才能在特质中使用unapply?
import play.api.libs.json.Json trait Json[T] { implicit val jsonFormat = Json.format[T] }
给出编译错误:
No unapply function found
我可以以某种方式强制编译器将T绑定到case类,以便我可以使用unapply吗?
解决方法
这是Scala
extractors存在的要求.提取器是一种称为unapply的方法,通常在对象中定义(通常是相关类型的伴随).它用于将价值结构化为其成分.
这是一个例子(非常做作):
object Extractor1 { def unapply(a: Any): Option[(String,Int)] = Some(a.toString,a.toString.length) } object ExtractorUse { import Extractor1._ def use { "23 skeedo!" match { case Extractor1(str,length) => printf("str=\"%s\"; length=%d%n",str,length) } } }
正在使用:
scala> ExtractorUse.use str="23 skeedo!"; length=10
如果提取器返回None,则尝试它的匹配将失败.同样,如果结果的arity与case子句中提供的pattern varibles不一致.