[Scala] Currying

Currying是一種函數式編程技巧, 指的是把接受多個參數的函數變換成接受一個單一參數的函數。

以一個簡單的例子在Scala中實現..


def f(a:Int, b:Int)={
a+b
}
//f(2,3)=5

//Currying
def curried(a:Int)(b:Int){
a+b
}
//f(2)(3)=5

 
看起來只是改變了放置參數的位置而已, 又有什麼用呢??
 
讓我們換個例子, 現在我們要實作出的Sumation函數,
 
而且其中f(x)是可代換的, 如,

,
…....等

先來看看Currying的Sumation函數的代碼吧!!


def sumation(func:Int=>Int )(a:Int,b:Int):Int={
if (a+1>b) 0
else sumation(func)(a+1,b)+func(a)

}

由Curring我拆成兩部分的參數

(func:Int=>Int ): 表示f(x)

(a:Int,b:Int): 表示Sumation的上下限範圍

這麼做的好處在於以代碼切分不同函數的概念不至於混雜,
增加代碼的可讀性與維護性

接下來讓我們來實作factorial函數

 


def factorial(n:Int):Int={
if (n==0) 1 else n*factorial(n-1)
}
sumation(factorial)(1,3)
//res0: Int = 9

   

 
 
 
 

[Scala] Currying,布布扣,bubuko.com

时间: 2024-12-17 08:01:03

[Scala] Currying的相关文章

Scala函数柯里化(Currying or Curry)

柯里化(Currying) 把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数而且返回结果的新函数的技术. 简单的实现如下: scala> def add(x:Int, y:Int) = x + y add: (x: Int, y: Int)Int 假如我们应用的时候,是这样的:add(1,2) 柯里化函数: scala> def add(x:Int)(y:Int) = x + y Curry化最大的意义在于把多个参数的function等价转化成多

Scala Learning(4): Currying柯里化的推演

本文展示加法和乘法的两个例子,最后使用MapReduce的思想把两者统一成一个带Currying的表达形式. 从high-order functions推演到Currying 原始方法 def sum(f: Int => Int, a: Int, b: Int): Int = if (a > b) 0 else f(a) + sum(f, a + 1, b) 表示从a到b,把每个int做一次f处理,把所有结果累加起来. 对应"加法"."立方"."

每天学一点Scala之 Currying函数

1.Curring函数 定义? 将原来接收两个参数的一个函数,转换为两个函数,第一个函数接收原先的第一个参数,然后返回接收原先第二个参数的第二个函数. 在函数调用的过程中,就变为了两个函数连续调用的形式 在marathon源码以及Spark的源码中,也有体现,所以对()()这种形式的Curring函数,要理解. 2.例子: object CurryingTest {    def main(args: Array[String]): Unit = {       println("---->

[翻译]The Neophyte's Guide to Scala Part 12: Type Classes

The Neophyte's Guide to Scala Part 12: Type Classes 过去的两周我们讨论了一些使我们保持DRY和灵活性的函数式编程技术,特别是函数组合,partial function的应用,以及currying.接下来,我将会继续讨论如何使你的代码尽可能的灵活. 但是,这次我们将不会讨论怎么使用函数作为一等对象来达到这个目的,而是使用类型系统,这次它不是阻碍着我们,而是使得我们的代码更灵活:你将会学到关于 type classes 的知识. 你可能会觉得这是一

Scala 中的函数式编程基础(二)

主要来自 Scala 语言发明人 Martin Odersky 教授的 Coursera 课程 <Functional Programming Principles in Scala>. 2. Higher Order Functions 把其他函数作为参数或者作为返回值,就是 higher order functions,python 里面也可以看到这样使用的情形.在酷壳上的博客有一个例子就是将函数作为返回值. 2.1 匿名函数 在 python 里边叫 lambda 函数,常常与 map(

scala学习笔记-函数式编程(14)

将函数赋值给变量 1 // Scala中的函数是一等公民,可以独立定义,独立存在,而且可以直接将函数作为值赋值给变量 2 // Scala的语法规定,将函数赋值给变量时,必须在函数后面加上空格和下划线 3 4 def sayHello(name: String) { println("Hello, " + name) } 5 val sayHelloFunc = sayHello _ 6 sayHelloFunc("leo") 匿名函数 1 // Scala中,函数

【Scala】高阶函数和柯里化

高阶函数 在数学和计算机科学中,高阶函数是至少满足下列一个条件的函数: - 接受一个或多个函数作为输入 - 输出一个函数 在数学中它们也叫做算子(运算符)或泛函.微积分中的导数就是常见的例子,因为它映射一个函数到另一个函数. 高阶函数的例子 假设有一个函数对给定两个数区间中的所有整数求和: def sumInts(a: Int, b: Int): Int = if(a > b) 0 else a + sumInts(a + 1, b) 如果现在要求连续整数的平方和: def square(x:

Scala 学习

1,Scala学习 官方网网站: http://www.scala-lang.org/ http://www.scala-lang.org/download/ 可伸缩的语言是一种多范式的编程语言,一种类似java的编程,设计初衷是要集成面向对象编程和函数式编程的各种特性. Scala是在JVM上运行. Scala有几项关键特性表明了它的面向对象的本质.例如,Scala中的每个值都是一个对象,包括基本数据类型(即布尔值.数字等)在内,连函数也是对象.另外,类可以被子类化,而且Scala还提供了基于

Scala函数式编程进阶

1 package com.dtspark.scala.basics 2 3 /** 4 * 函数式编程进阶: 5 * 1,函数和变量一样作为Scala语言的一等公民,函数可以直接赋值给变量: 6 * 2, 函数更长用的方式是匿名函数,定义的时候只需要说明输入参数的类型和函数体即可,不需要名称,但是如果你要使用的话,一般会把这个匿名函数赋值给一个变量(其实是val常量),Spark源码中大量存在这种语法,必须掌握: 7 * 3, 函数可以作为参数直接传递给函数,这极大的简化的编程的语法,为什么这