Was macht der @ Operator von Scala?
Zum Beispiel gibt es in dem Blog-Beitrag Formale Sprachverarbeitung in Scala, Teil 2 so etwas
case x @ Some(Nil) => x
Was macht der @ Operator von Scala?
Zum Beispiel gibt es in dem Blog-Beitrag Formale Sprachverarbeitung in Scala, Teil 2 so etwas
case x @ Some(Nil) => x
Antworten:
Es ermöglicht das Binden eines übereinstimmenden Musters an eine Variable. Betrachten Sie zum Beispiel Folgendes:
val o: Option[Int] = Some(2)
Sie können den Inhalt einfach extrahieren:
o match {
case Some(x) => println(x)
case None =>
}
Was aber , wenn man wollte nicht den Inhalt von Some
, sondern die Möglichkeit , selbst? Das würde damit erreicht werden:
o match {
case x @ Some(_) => println(x)
case None =>
}
Beachten Sie, dass @
dies auf jeder Ebene verwendet werden kann, nicht nur auf der obersten Ebene des Matchings.
_*
). Aber vielleicht wurde dies in einer neueren Version der Spezifikation geklärt.
@
mit verwenden würden Some(_)
, sondern wenn Sie auf den Inhalt der übereinstimmen möchten Some
, aber immer noch auf die Einige selbst verweisen, z case x @ Some(7) => println(x)
. Wie ich interpretiere, case x @ Some(_)
ist es nur eine ausführlichere Version von case x: Some
.
case x: Some
funktioniert nicht alleine. Sie müssen verwenden case x: Some[_]
, was nicht weniger ausführlich ist
@
kann verwendet werden, um einen Namen an ein erfolgreich übereinstimmendes Muster oder Untermuster zu binden. Muster können beim Mustervergleich, auf der linken Seite des <-
In zum Verständnis und bei der Destrukturierung von Aufgaben verwendet werden.
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)
Ermöglicht das Anpassen der obersten Ebene eines Musters. Beispiel:
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) }
Es setzt den Wert von x
auf das Muster, das übereinstimmt. In Ihrem Beispiel x
wäre daher Some(Nil)
(wie Sie aus einem Aufruf an println feststellen könnten )