一.本章要点

  • 在Scala中函数是”头等公民“(可以作为参数,返回值,赋值给其他);
  • 可以创建匿名函数,通常还会交给其他函数;
  • 函数参数可以给出需要稍后执行的行为;
  • 许多集合方法都接受函数参数,将函数应用到集合中的值;
  • 有许多语法上的简写让你以简短且易读的方式表达函数参数;
  • 可以创建操作代码块的函数,像是内建的控制语句

二.作为值的函数

  在Scala中,函数是头等公民,和数字一样,在变量中存放函数:

import scala.math._
val num=3.14
val fun=ceil _
//注:ceil函数后的_意味确实指的这个函数,而不是忘记传参数,可以调用它,传递它

三.匿名函数

  没有函数名的函数,例val triple=(x:Double) => 3*x等同于def triple(x:Double)=3*x。

  Array(3.14,1.43,2.0).map((x:Double)=>3*x),map也可以用{},Array(3.14,1.43,2.0).map{(x:Double)=>3*x},Array(3.14,1.43,2.0) map {(x:Double)=>3*x}

四.带函数参数的函数

  如 def valueAtOneQuarter(f:(Double) => Double)=f(0.25),可以接受参数的函数,也是高阶函数,类型是(参数类型) = >结果类型,则该函数为((Double)=>Double)=>Double,也可以返回一个函数,例def nulBy(factor:Double)=(x:Double)=>factor*x,类型为(Double)=>((Double)=>Double)。

五.参数(类型)推断

  当将一个匿名函数传递给另一个函数或者方法时,Scala会尽可能帮你推断出类型信息,例:valueAtOneQuarter((x:Double)=>3*x)简写为valueAtOneQuarter((x)=>3*x),一个参数还可以valueAtOneQuarter(x=>3*x),如果=>只出现一次,还可以valueAtOneQuarter(3* _)。

六.一些有用的高阶函数

  map作用到某个集合的所有元素并返回结果,foreach也是作用于某个集合的所有元素但无返回值,fileter接受集合筛选匹配特定条件的值,reduceLeft接受二元函数,并应用到序列所有函数。  

七.闭包

  能够读取其他函数内部的函数,由代码和代码用到的任何非局部变量定义构成。  

八.SAM转换

  SAM:在Java中,将动作放在一个实现某接口的类中,然后将该类的一个实例传递给另一个方法,且这些接口只有单个抽象方法,这被叫做SAM模型。

  需要用到隐式转换(implicit),例:

九.柯里化

  指将原来接受两个参数的函数变为新的接受一个参数的函数的过程,有时候需要把某个参数拿出来提供更多用于类型判断的信息。

  如:def mul(x:Int,y:Int)=x*y转换为def mulOnrAtTime(x:Int)=(y:Int)=>x*y,还可以简写为def nulOneAtTme(x:Int)(y:Int)=x*y

十.控制抽象

  将一系列语句组成不带参数也没有返回值的函数。

def runInThread(block:()=>Unit){
new Thread{
override def run(){block()}
}.start()} //调用
runInThread(println("Hi");Thread.sleep(10000);println("Bye")) //利用换名表示方法省掉=>
def runInThread(block:=>Unit){
new Thread{
override def run(){block()}.start()}
}
//调用
runInThread(println("Hi");Thread.sleep(10000);println("Bye"))

十一.return表达式

  在Scala中,不需要用return语句返回函数值,函数的返回值就是函数体的值。

  可以用return来从一个匿名函数中返回值包含这个匿名函数的带名函数,例:

def indexOf(str:String,ch:Char):Int={
var i=0
util(i==str.length){
if(str(i)==ch)return i
i+=1
}
return -1
}

十二.练习

Scala学习十二——高阶函数的更多相关文章

  1. scala学习笔记:高阶函数

    scala> def power(y:Double)=(x:Double)=>Math.pow(x,y) warning: there were 1 deprecation warning ...

  2. JavaScript学习笔记(十)——高阶函数之map,reduce,filter,sort

    在学习廖雪峰前辈的JavaScript教程中,遇到了一些需要注意的点,因此作为学习笔记列出来,提醒自己注意! 如果大家有需要,欢迎访问前辈的博客https://www.liaoxuefeng.com/ ...

  3. python六十课——高阶函数之map

    1.高阶函数: 特点:函数的形参位置必须接受一个函数对象 分类学习: 1).map(fn,lsd1,[lsd2...]): 参数一:fn --> 函数对象 参数二:lsd1 --> 序列对 ...

  4. spark快速开发之scala基础之5高阶函数,偏函数,闭包

    高阶函数 高阶函数就是将函数作为参数或者返回值的函数. object function { def main(args: Array[String]): Unit = { println(test(f ...

  5. Python学习笔记系列——高阶函数(map/reduce)

    一.map #变量可以指向函数,函数的参数能接受变量,那么一个函数就可以接受另一个函数作为参数,这种函数被称之为高阶函数 def add(x,y,f): return f(x)+f(y) print( ...

  6. Python学习 Day 5 高阶函数 map/reduce filter sorter 返回函数 匿名函数 装饰器 偏函数

    高阶函数Higher-orderfunction 变量可以指向函数 >>> abs #abs(-10)是函数调用,而abs是函数本身 <built-in function ab ...

  7. Python学习笔记系列——高阶函数(filter/sorted)

    一.filter #filter()函数用于过滤序列.和map()类似,也接收一个函数和一个序列,把函数依次作用于每个元素,根据返回值是True还是False决定是否保留该元素. #filter()函 ...

  8. scala 学习笔记二 方法与函数

    1.介绍 Scala 有方法与函数,二者在语义上的区别很小.Scala 方法是类的一部分,而函数是一个对象可以赋值给一个变量.换句话来说在类中定义的函数即是方法. Scala 中的方法跟 Java 的 ...

  9. 【Python学习之六】高阶函数2(map、reduce、filter、sorted)

    3.filter filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃该元素.相当于一 ...

随机推荐

  1. 在CSS中水平居中和垂直居中:完整的指南

    这篇文章将会按照如下思路展开: 一.水平居中 1. 行内元素水平居中 2. block元素水平居中 3. 多个块级元素水平居中 二.垂直居中 1. 行内元素水平居中 2. block元素水平居中 3. ...

  2. Java-JVM OutOfMemory 情况(JDK8)

    JVM 运行时内存结构(Run-Time Data Areas) 内存溢出分为两大类:OutOfMemoryError 和 StackOverflowError. 一.HeapOomError (JV ...

  3. dubbo备忘

    http://start.dubbo.io/ https://github.com/dubbo/dubbo-samples https://www.aliyun.com/product/edas ht ...

  4. leetcode-hard-array-149. Max Points on a Line -NO

    mycode  不会.... 参考 因为每次遍历一个点,也就是i的时候,都是新建的一个lines,所以也就是考虑了k相同b不同的情况 最后gcd函数就求最大公约数,来解决斜率精度的问题 class S ...

  5. Undo Segment/Undo Retention

    undo_retention简单定义,就是最多数据的最少保留时间.AUM模式下,undo_retention参数用于事务commit后undo数据保留的时间.单位为秒.这是个no guarantee的 ...

  6. Mac下持续集成-Mac下Tomcat+Jenkins集成环境搭建

    一.MAC安装jdk及环境变量配置 1)访问Oracle官网 http://www.oracle.com,浏览到首页的底部菜单 ,然后按下图提示操作: 2)下载完成后点击安装包,按提示即可完成安装. ...

  7. 前端知识点回顾之重点篇——JavaScript异步机制

    JavaScript异步机制 来源:https://www.cnblogs.com/zhaodongyu/p/3922961.html JavaScript是单线程异步执行的,单线程意味着代码在任务队 ...

  8. MYSQL通过循环向数据库中插入数据

    BEGINdeclare i int default 305;declare a char(255);REPEATset a=concat("测试机构00",cast(i as c ...

  9. BCNF/3NF的判断方法

    判断是否是 3NF 的条件: 对于 R 上的每个函数依赖 X->A (X 是关系 R 属性的一个子集,A 是 R 的一个属性) ,以下条件中的一个成立:1 X ∈ A2 X 是超码3 A 是 R ...

  10. 机器学习之DBSCAN聚类算法

    可以看该博客:https://www.cnblogs.com/aijianiula/p/4339960.html 1.知识点 """ 基本概念: 1.核心对象:某个点的密 ...