Scala中Case类怎么用

这篇文章将为大家详细讲解有关Scala中Case类怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

创新互联网站建设公司,提供网站建设、做网站,网页设计,建网站,PHP网站建设等专业做网站服务;可快速的进行网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,是专业的做网站团队,希望更多企业前来合作!

Scala支持case类的概念。case类也是正规的类,暴露其构造器参数,并通过模式匹配提供递归解构机制。 以下是由抽象超类Term和三个具体case类Var,Fun,和App组成的类层次的例子。

abstract class Term  case class Var(name: String) extends Term  case class Fun(arg: String, body: Term) extends Term  case class App(f: Term, v: Term) extends Term

这个类层次可以用来表现无类型lambda算子。为了便于case类实例的构建,Scala不需要使用new原语。只要简单地把类名用作函数即可。举例如下:

Fun("x", Fun("y", App(Var("x"), Var("y"))))

case类的构造器参数被当作公开值并可以直接被访问。

val x = Var("x")  Console.println(x.name)

对于每个case类,Scala编译器将产生实现了结构相等性检查的equals方法和一个toString方法。举例如下:

val x1 = Var("x")  val x2 = Var("x")  val y1 = Var("y")  println("" + x1 + " == " + x2 + " => " + (x1 == x2))  println("" + x1 + " == " + y1 + " => " + (x1 == y1))

将打印

Var(x) == Var(x) => true Var(x) == Var(y) => false

只有在分解数据结构的时候用到了模式匹配的情况下,定义case类才是有意义的。以下的对象为我们的lambda算子的展示定义了漂亮的打印函数:

object TermTest extends Application {    def printTerm(term: Term) {      term match {        case Var(n) =>          print(n)        case Fun(x, b) =>          print("^" + x + ".")          printTerm(b)        case App(f, v) =>          Console.print("(")          printTerm(f)          print(" ")          printTerm(v)          print(")")      }    }    def isIdentityFun(term: Term): Boolean = term match {      case Fun(x, Var(y)) if x == y => true     case _ => false   }    val id = Fun("x", Var("x"))    val t = Fun("x", Fun("y", App(Var("x"), Var("y"))))    printTerm(t)    println    println(isIdentityFun(id))    println(isIdentityFun(t))  }

我们的例子里,函数print表达为开始于match关键字的,由一系列的case Pattern => Body子句组成的模式匹配语句。

上面的程序还定义了函数isIdentityFun,用来检查是否给定的term对应于一个简单的身份函数。这个例子使用了深度模式和护卫语句。在使用给定值匹配了模式之后,护卫语句(定义于关键字if之后)被执行评估。如果返回true,匹配成功;反之,则匹配失败,并尝试下一个模式。

关于“Scala中Case类怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


网页标题:Scala中Case类怎么用
本文链接:http://scyanting.com/article/jeihsg.html