Co robi operator @ Scali?
Na przykład w poście na blogu Formal Language Processing in Scala, część 2 jest coś takiego
case x @ Some(Nil) => x
Co robi operator @ Scali?
Na przykład w poście na blogu Formal Language Processing in Scala, część 2 jest coś takiego
case x @ Some(Nil) => x
Umożliwia powiązanie dopasowanego wzorca ze zmienną. Weźmy na przykład pod uwagę następujące kwestie:
val o: Option[Int] = Some(2)
Możesz łatwo wyodrębnić zawartość:
o match {
case Some(x) => println(x)
case None =>
}
Ale co, jeśli nie chciał się zawartość z Some
, ale sam opcję? Można to osiągnąć dzięki temu:
o match {
case x @ Some(_) => println(x)
case None =>
}
Zwróć uwagę, że @
można go użyć na dowolnym poziomie, a nie tylko na najwyższym poziomie dopasowania.
_*
). Ale może zostało to wyjaśnione w nowszej wersji specyfikacji.@
zSome(_)
, a raczej gdybyś chciał dopasować zawartość po zawartościSome
, ale nadal odnosisz się do samego Some npcase x @ Some(7) => println(x)
. Jak interpretuję, jestcase x @ Some(_)
to po prostu bardziej szczegółowa wersjacase x: Some
.case x: Some
nie działa samodzielnie. Musisz użyćcase x: Some[_]
, co jest nie mniej@
może służyć do wiązania nazwy z pomyślnie dopasowanym wzorcem lub wzorcem podrzędnym. Wzorce mogą być używane w dopasowywaniu wzorców, po lewej stronie<-
do rozumienia i podczas destrukcji przypisań.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)
źródło
Kiedy dopasowanie do wzorca
variable @ pattern
wiąże zmienną z wartością dopasowaną do wzorca, jeśli wzorzec pasuje. W tym przypadku oznacza to, że wartośćx
will będzieSome(Nil)
w tej klauzuli.źródło
Umożliwia dopasowanie najwyższego poziomu wzoru. Przykład:
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) }
źródło
Ustawia wartość
x
wzorca, który pasuje. W twoim przykładziex
byłby zatemSome(Nil)
(jak można określić na podstawie wywołania println )źródło