Что делает оператор @ в Scala?
Например, в сообщении блога « Обработка формального языка в Scala, часть 2» есть что-то вроде этого
case x @ Some(Nil) => x
Что делает оператор @ в Scala?
Например, в сообщении блога « Обработка формального языка в Scala, часть 2» есть что-то вроде этого
case x @ Some(Nil) => x
Ответы:
Это позволяет привязать согласованный шаблон к переменной. Рассмотрим, например, следующее:
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[_]
, что не менее многословно,
@
может использоваться для привязки имени к успешно подобранному шаблону или подшаблону. Шаблоны могут использоваться для сопоставления с образцом, левой части <-
in для понимания и для деструктурирования заданий.
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) }
Он устанавливает значение x
соответствующего шаблона. В вашем примере, x
следовательно, будет Some(Nil)
(как вы могли определить по вызову println )