下面的对象L1
有效。我可以通过传入varargs来“创建”L1
,这很好,但我希望能够使用相同的语法分配给L1
。不幸的是,我在这里完成它的方式需要在Array
内嵌套L1
的更粗略的语法。
object L1 {
def apply(stuff: String*) = stuff.mkString(",")
def unapply(s: String) = Some(s.split(","))
}
val x1 = L1("1", "2", "3")
val L1(Array(a, b, c)) = x1
println("a=%s, b=%s, c=%s".format(a,b,c))
我尝试以一种显而易见的方式实现这一点,如下面的L2
:
object L2 {
def apply(stuff: String*) = stuff.mkString(",")
def unapply(s: String) = Some(s.split(","):_*)
}
val x2 = L2("4", "5", "6")
val L2(d,e,f) = x2
println("d=%s, e=%s, f=%s".format(d,e,f))
但这会给出错误:
error: no `: _*' annotation allowed here
(such annotations are only allowed in arguments to *-parameters)`.
unapply
是否有可能以这种方式使用varargs?
答案 0 :(得分:22)
我认为你想要的是unapplySeq。 Jesse Eichar在unapplySeq
上写得很好scala> object L2 {
| def unapplySeq(s: String) : Option[List[String]] = Some(s.split(",").toList)
| def apply(stuff: String*) = stuff.mkString(",")
| }
defined module L2
scala> val x2 = L2("4", "5", "6")
x2: String = 4,5,6
scala> val L2(d,e,f) = x2
d: String = 4
e: String = 5
f: String = 6