Thinking in scala (5)----高阶函数*】的更多相关文章

在Thinking in scala (5)----高阶函数* 里面,我们演示了如何把一个函数作为参数传递给另外一个函数. 在本文里面,我们来演示函数式编程另外一个重要的特性:返回一个函数.首先来看这么一段代码: code piece 1: def sum(f:Int=>Int):(Int,Int)=>Int={ def sumF(a:Int,b:Int):Int= if(a>b) 0 else f(a)+sumF(a+1,b) sumF } 一点点来看,f:Int=>Int 是s…
高阶函数是函数式编程里面一个非常重要的特色,所谓的高阶函数,就是以其它函数作为参数的函数. 下面以一个小例子演示Scala的高阶函数特性,非常有意思,也非常强大. 首先看这么一个程序: code1: object higherorderfuntion{ def sum1(a:Int,b:Int):Int= if(a>b) 0 else a+sum1(a+1,b) def sum2(a:Int,b:Int):Int= if(a>b) 0 else cube(a)+sum2(a+1,b) def…
1.定义一个类 class Person{ //用val修饰的变量是只读属性,有getter但是没有setter val id ="111" //用var修饰的变量既有getter又有setter var age:Int =18 //类私有字段,只能在类的内部使用,只有伴生对象内可以使用 private var name:String ="aaa" //对象是由字段,访问权限更加严格,只有person类的方法才能访问当前对象的pet字段 private[this]v…
构造器 在定义类时可以定义主构造器.主构造器可以同时声明字段. /** * 主构造器 * @author Administrator */ //在scala中,类和方法交织在一起 class TestClass51(val name:String = "" ,val age:Int = 0){ println("name="+ name + " age=" + age) } object TestScala51 { def main(args:…
函数式编程的崛起 函数式编程中的“值不可变性”避免了对公共的可变状态进行同步访问控制的复杂问题,能够较好满足分布式并行编程的需求,适应大数据时代的到来. 函数是第一等公民 可以作为实参传递给另外一个函数 可以作为返回值 可以赋值给变量 可以存储在数据结构里 def greeting() = (name: String) => { s"Hello" + " " + name } //> greeting: ()String => String gre…
高阶函数 高阶函数就是将函数作为参数或者返回值的函数. object function { def main(args: Array[String]): Unit = { println(test(f,10)) } def test(f:Int => String , num : Int) = f(num) def f(num:Int) : String = { 10 + num + "" } } 在spark中,经常将只需要执行一次的函数定义为匿名函数作为参数传递给高阶函数.如…
class TypeInfer(self: Int, other: Int) { def test(num: Int, word: String, fun1: (Int, Int) => Int): Unit = { fun1(self, other) } def test(word: String, num: Int, fun1: (Int, Int) => Int): Unit = { fun1(self, other) } def test1(num: String, word: Int…
1.作为参数的函数 函数可以作为一个参数传入到一个方法当中去 def main(args: Array[String]): Unit = { val myFunc1 =(x:Int) =>{ x * x } val myArray = Array(1,3,5,7,9).map(myFunc1) println(myArray.mkString(",")) } 2.匿名函数 没有名字的函数即是匿名函数,我们可以通过函数表达式来设置匿名函数 def main(args: Array[…
版权申明:转载请注明出处. 文章来源:http://bigdataer.net/?p=332 排版乱?请移步原文获得更好阅读体验 1.scala中的函数 scala是一门面向对象和函数式编程相结合的语言,前面的文章已经讲了类.对象.继承等面向对象特有的语言特性,接下来将关注一下函数式编程的相关知识.在scala中,函数和变量一样,都是scala的一等公民.与函数相关的代码片段如下: scala    7行 //定义一个匿名函数 (x:Int) => 3*x //将函数赋值给一个变量 val fu…
1. Scala中的函数 在Scala中,函数是“头等公民”,就和数字一样.可以在变量中存放函数,即:将函数作为变量的值(值函数). 2. scala中的匿名函数,即没有函数名称的函数,匿名函数常作为高阶函数的参数使用 (x: Int) => x*3 =>使用场景小结: a. 用于匿名函数中连接函数声明和函数体 b. 用于模式匹配中,连接case条件和表达式  case "+" => "This is a positive number" c. 用…