Answers:
它使人们能够将匹配的模式绑定到变量。例如,考虑以下内容:
val o: Option[Int] = Some(2)
您可以轻松提取内容:
o match {
case Some(x) => println(x)
case None =>
}
但是,如果您不想 内容的Some
,但选择本身?可以这样实现:
o match {
case x @ Some(_) => println(x)
case None =>
}
请注意,它@
可以在任何级别使用,而不仅限于匹配的最高级别。
_*
)。但是,也许在更新版本的规范中已经阐明了这一点。
@
与with一起使用Some(_)
,而是希望与的内容匹配Some
,但仍引用Some本身,例如case x @ Some(7) => println(x)
。根据我的解释,它case x @ Some(_)
只是的更详细的版本case x: Some
。
case x: Some
不能独立工作。你必须使用case x: Some[_]
,这是不那么冗长
@
可用于将名称绑定到成功匹配的模式或子模式。模式可用于模式匹配,输入的左手侧<-
以进行理解,以及用于销毁配置。
scala> val d@(c@Some(a), Some(b)) = (Some(1), Some(2))
d: (Some[Int], Some[Int]) = (Some(1),Some(2))
c: Some[Int] = Some(1)
a: Int = 1
b: Int = 2
scala> (Some(1), Some(2)) match { case d@(c@Some(a), Some(b)) => println(a, b, c, d) }
(1,2,Some(1),(Some(1),Some(2)))
scala> for (x@Some(y) <- Seq(None, Some(1))) println(x, y)
(Some(1),1)
scala> val List(x, xs @ _*) = List(1, 2, 3)
x: Int = 1
xs: Seq[Int] = List(2, 3)
允许您匹配模式的顶层。例:
case x @ "three" => assert(x.equals("three"))
case x @ Some("three") => assert(x.get.equals("three")))
case x @ List("one", "two", "three") => for (element <- x) { println(element) }