Scala - Pencocokan Pola

Pencocokan pola adalah fitur Scala kedua yang paling banyak digunakan, setelah nilai fungsi dan closure. Scala memberikan dukungan yang bagus untuk pencocokan pola, dalam memproses pesan.

Pencocokan pola mencakup urutan alternatif, masing-masing dimulai dengan kata kunci case. Setiap alternatif mencakup apattern dan satu atau lebih expressions, yang akan dievaluasi jika polanya cocok. Simbol panah => memisahkan pola dari ekspresi.

Coba program contoh berikut, yang menunjukkan cara mencocokkan dengan nilai integer.

Contoh

object Demo {
   def main(args: Array[String]) {
      println(matchTest(3))
   }
   
   def matchTest(x: Int): String = x match {
      case 1 => "one"
      case 2 => "two"
      case _ => "many"
   }
}

Simpan program di atas dalam Demo.scala. Perintah berikut digunakan untuk mengkompilasi dan menjalankan program ini.

Perintah

\>scalac Demo.scala
\>scala Demo

Keluaran

many

Blok dengan pernyataan case mendefinisikan sebuah fungsi, yang memetakan integer ke string. Kata kunci pencocokan memberikan cara yang nyaman untuk menerapkan fungsi (seperti fungsi pencocokan pola di atas) ke objek.

Coba program contoh berikut, yang mencocokkan nilai dengan pola jenis yang berbeda.

Contoh

object Demo {
   def main(args: Array[String]) {
      println(matchTest("two"))
      println(matchTest("test"))
      println(matchTest(1))
   }
   
   def matchTest(x: Any): Any = x match {
      case 1 => "one"
      case "two" => 2
      case y: Int => "scala.Int"
      case _ => "many"
   }
}

Simpan program di atas dalam Demo.scala. Perintah berikut digunakan untuk mengkompilasi dan menjalankan program ini.

Perintah

\>scalac Demo.scala
\>scala Demo

Keluaran

2
many
one

Pencocokan menggunakan Kelas Kasus

Itu case classesadalah kelas khusus yang digunakan dalam pencocokan pola dengan ekspresi kasus. Secara sintaksis, ini adalah kelas standar dengan pengubah khusus:case.

Coba yang berikut ini, ini adalah contoh pencocokan pola sederhana menggunakan kelas kasus.

Contoh

object Demo {
   def main(args: Array[String]) {
      val alice = new Person("Alice", 25)
      val bob = new Person("Bob", 32)
      val charlie = new Person("Charlie", 32)
   
      for (person <- List(alice, bob, charlie)) {
         person match {
            case Person("Alice", 25) => println("Hi Alice!")
            case Person("Bob", 32) => println("Hi Bob!")
            case Person(name, age) => println(
               "Age: " + age + " year, name: " + name + "?")
         }
      }
   }
   case class Person(name: String, age: Int)
}

Simpan program di atas dalam Demo.scala. Perintah berikut digunakan untuk mengkompilasi dan menjalankan program ini.

Perintah

\>scalac Demo.scala
\>scala Demo

Keluaran

Hi Alice!
Hi Bob!
Age: 32 year, name: Charlie?

Menambahkan kata kunci case menyebabkan kompilator menambahkan sejumlah fitur berguna secara otomatis. Kata kunci menyarankan hubungan dengan ekspresi kasus dalam pencocokan pola.

Pertama, kompilator secara otomatis mengubah argumen konstruktor menjadi bidang yang tidak dapat diubah (vals). Kata kunci val adalah opsional. Jika Anda ingin bidang yang bisa diubah, gunakan kata kunci var. Jadi, daftar argumen konstruktor kami sekarang lebih pendek.

Kedua, kompilator secara otomatis mengimplementasikan equals, hashCode, dan toStringmetode ke kelas, yang menggunakan bidang yang ditentukan sebagai argumen konstruktor. Jadi, kita tidak lagi membutuhkan metode toString () kita sendiri.

Terakhir, juga tubuh Person kelas menjadi kosong karena tidak ada metode yang perlu kita definisikan!