一.本章要点

  • 在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. Java虚拟机与平台无关性

    概述 代码编译的结果从本地机器码转变为字节码,是存储格式发展的一小步,却是编程语言发展的一大步. --<深入理解Java虚拟机>(从这里可以看到,字节码是一种文件格式) 我们都知道计算机只 ...

  2. 整合pjax无刷新

    一:整合pjax的准备工作: 检查你的网站是否引入1.7.0版本以上的jquery.js,如果没有请全局引入 1.新浪CDN提速:<script type="text/javascri ...

  3. github pr

    github----向开源框架提交pr的过程 https://blog.csdn.net/vim_wj/article/details/78300239github 的 pr 使用方法 https:/ ...

  4. 【Webscraper】不懂编程也能爬虫

    一.配置环境 在浏览器中安装web scraper插件. 所有安装包下载链接: https://pan.baidu.com/s/1CfAWf0wMO6WqicoUgdYgkg 提取码: nn2e 安装 ...

  5. 3.ibatis4种事务类型浅析

    ibatis中Transaction有四个实现类 其中spring的SqlMapClientFactoryBean类中 private Class transactionConfigClass = E ...

  6. C#txt文件创建并写入信息

    public static void LogWrite(string str) { //项目根目录 string path = HttpContext.Current.Server.MapPath(& ...

  7. 记一次ceph集群的严重故障 (转)

    问题:集群状态,坏了一个盘,pg状态好像有点问题[root@ceph-1 ~]# ceph -s    cluster 72f44b06-b8d3-44cc-bb8b-2048f5b4acfe     ...

  8. Kafka API使用

  9. CPU-内存-IO-网络调优

    一.关于CPU 中央处理器调优 1. CPU处理方式: 批处理,顺序处理请求.(切换次数少,吞吐量大) 分时处理.(如同"独占",吞吐量小)(时间片,把请求分为一个一个的时间片,一 ...

  10. delphi循环校验数据集

    function XXXXXFrom.CheckData(Sender: TObject): Boolean; var tmpcds:TfwClientDataset; begin Result:=F ...