当前位置:K88软件开发文章中心编程语言SQLscala → 文章内容

模式匹配与函数组合

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-19 4:45:27

由 Shaodengdeng 创建, 最后一次修改 2016-08-12 模式匹配与函数组合函数组合让我们创建两个函数:scala> def f(s: String) = "f(" + s + ")"f: (String)java.lang.Stringscala> def g(s: String) = "g(" + s + ")"g: (String)java.lang.Stringcomposecompose 组合其他函数形成一个新的函数 f(g(x))scala> val fComposeG = f _ compose g _fComposeG: (String) => java.lang.String = <function>scala> fComposeG("yay")res0: java.lang.String = f(g(yay))andThenandThen 和 compose很像,但是调用顺序是先调用第一个函数,然后调用第二个,即g(f(x))scala> val fAndThenG = f _ andThen g _fAndThenG: (String) => java.lang.String = <function>scala> fAndThenG("yay")res1: java.lang.String = g(f(yay))柯里化 vs 偏应用case 语句那么究竟什么是 case 语句?这是一个名为 PartialFunction 的函数的子类。多个 case 语句的集合是什么?他们是共同组合在一起的多个 PartialFunction。理解 PartialFunction(偏函数)对给定的输入参数类型,函数可接受该类型的任何值。换句话说,一个(Int) => String的函数可以接收任意 Int 值,并返回一个字符串。对给定的输入参数类型,偏函数只能接受该类型的某些特定的值。一个定义为(Int) => String 的偏函数可能不能接受所有 Int 值为输入。isDefinedAt 是 PartialFunction 的一个方法,用来确定 PartialFunction 是否能接受一个给定的参数。注意:偏函数 PartialFunction 和我们前面提到的部分应用函数是无关的。参考 Effective Scala 对 [PartialFunction](http://twitter.github.com/effectivescala/#Functional programming-Partial functions) 的意见。scala> val one: PartialFunction[Int, String] = { case 1 => "one" }one: PartialFunction[Int,String] = <function1>scala> one.isDefinedAt(1)res0: Boolean = truescala> one.isDefinedAt(2)res1: Boolean = false您可以调用一个偏函数。scala> one(1)res2: String = onePartialFunctions 可以使用 orElse 组成新的函数,得到的 PartialFunction 反映了是否对给定参数进行了定义。scala> val two: PartialFunction[Int, String] = { case 2 => "two" }two: PartialFunction[Int,String] = <function1>scala> val three: PartialFunction[Int, String] = { case 3 => "three" }three: PartialFunction[Int,String] = <function1>scala> val wildcard: PartialFunction[Int, String] = { case _ => "something else" }wildcard: PartialFunction[Int,String] = <function1>scala> val partial = one orElse two orElse three orElse wildcardpartial: PartialFunction[Int,String] = <function1>scala> partial(5)res24: String = something elsescala> partial(3)res25: String = threescala> partial(2)res26: String = twoscala> partial(1)res27: String = onescala> partial(0)res28: String = something elsecase 之谜上周我们看到一些新奇的东西。我们在通常应该使用函数的地方看到了一个 case 语句。scala> case class PhoneExt(name: String, ext: Int)defined class PhoneExtscala> val extensions = List(PhoneExt("steve", 100), PhoneExt("robey", 200))extensions: List[PhoneExt] = List(PhoneExt(steve,100), PhoneExt(robey,200))scala> extensions.filter { case PhoneExt(name, extension) => extension < 200 }res0: List[PhoneExt] = List(PhoneExt(steve,100))为什么这段代码可以工作?filter 使用一个函数。在这个例子中是一个谓词函数(PhoneExt) => Boolean。PartialFunction 是 Function 的子类型,所以 filter 也可以使用 PartialFunction!

模式匹配与函数组合