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[String]): Unit = {

val hiddenFunc = (x:Int,y:String) => x + y

println(hiddenFunc)

}

3、高阶函数

1、能够接受函数作为参数的方法,叫做高阶函数

def main(args: Array[String]): Unit = {

val func3:(Int,String) =>(String,Int)={

(x,y)=>(y,x)

}

def myMethod3(hello:(Int,String) => (String,Int)):Int ={

val resultFunc = hello(20,"hello")

resultFunc._2

}

println(myMethod3(func3))

}

2、高阶函数同样可以返回一个函数类型

def main(args: Array[String]): Unit = {

def myFunc4(x:Int) = (y:String) => y

println(myFunc4(50))

}

4、参数类型推断

def main(args: Array[String]): Unit = {

val array = Array(1,2,3,4,5,6,7,8,9)

//map当中需要传入一个函数,我们可以直接定义一个函数

array.map((x:Int) => x * 2 )

//进一步化简参数推断省去类型信息

array.map((x) => x * 2 )

//进一步化简单个参数可以省去括号

array.map( x => x * 2 )

//进一步化简如果变量只在=>右边只出现一次,可以用_来代替

array.map( 2 * _ )

}

5、闭包与柯里化

柯里化是scala当中面向函数式编程导致的一种必然的结果,最终推导而来产生的一种现象

def main(args: Array[String]): Unit = {

//柯里化的定义形式

def kery(x:Int)(y:Int):Int={

x + y

}

println(kery(3)(5))

//柯里化的推导过程,注意方法的返回值不要定义任何的返回值类型

val keryResult = (x:Int) => (y:Int) => {x + y}

def keryMethod(x:Int) ={

(y:Int) => x+ y

}

println(keryMethod(20))

println(keryMethod(20)(10))

//注意,方法当中的函数,调用了方法的参数,就叫做闭包

}

再来看一个案例

/**

* 柯里化的应用,比较数组集合当中两个对应下标字符串是否相等

* @param args

*/

def main(args: Array[String]): Unit = {

val a = Array("Hello", "World")

val b = Array("hello", "world")

println(a.corresponds(b)(_.equalsIgnoreCase(_)))

}

Scala高阶函数的更多相关文章

  1. scala高阶函数类型推断什么时候失效?

    class TypeInfer(self: Int, other: Int) { def test(num: Int, word: String, fun1: (Int, Int) => Int ...

  2. Scala高阶函数与泛型

    1. Scala中的函数 在Scala中,函数是“头等公民”,就和数字一样.可以在变量中存放函数,即:将函数作为变量的值(值函数). 2. scala中的匿名函数,即没有函数名称的函数,匿名函数常作为 ...

  3. Scala高阶函数实践

    高阶函数主要有两种:一种是将一个函数当做另外一个函数的参数(即函数参数):另外一种是返回值是函数的函数.package sparkCore/** * Created by zhen on 2018/3 ...

  4. Scala高阶函数示例

    object Closure { def function1(n: Int): Int = { val multiplier = (i: Int, m: Int) => i * m multip ...

  5. Scala中的构造器和高阶函数

    构造器 在定义类时可以定义主构造器.主构造器可以同时声明字段. /** * 主构造器 * @author Administrator */ //在scala中,类和方法交织在一起 class Test ...

  6. Thinking in scala (6)----高阶函数----返回一个函数

    在Thinking in scala (5)----高阶函数* 里面,我们演示了如何把一个函数作为参数传递给另外一个函数. 在本文里面,我们来演示函数式编程另外一个重要的特性:返回一个函数.首先来看这 ...

  7. Thinking in scala (5)----高阶函数*

    高阶函数是函数式编程里面一个非常重要的特色,所谓的高阶函数,就是以其它函数作为参数的函数. 下面以一个小例子演示Scala的高阶函数特性,非常有意思,也非常强大. 首先看这么一个程序: code1: ...

  8. Scala - 快速学习08 - 函数式编程:高阶函数

    函数式编程的崛起 函数式编程中的“值不可变性”避免了对公共的可变状态进行同步访问控制的复杂问题,能够较好满足分布式并行编程的需求,适应大数据时代的到来. 函数是第一等公民 可以作为实参传递给另外一个函 ...

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

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

随机推荐

  1. JDK1.7新特性(1):Switch和数字

    Switch jdk1.7的switch语句增加了对字符串类型的支持.其实现的原理是通过字符串的hash值来比较的,代码示例如下: String name = "KiDe"; // ...

  2. Metronic 对话 chat

    http://keenthemes.com/preview/metronic/theme/admin_1/index.html: jquery让滚动条默认在最底部:$('#content').scro ...

  3. 转【js & jquery】遮罩层实现禁止a、span、button等元素的鼠标事件

    /*遮罩层代码 作用:通过遮罩层的方式防止表单提交次数过多 */ function MaskIt(obj){ var hoverdiv = '<div class="divMask&q ...

  4. Java基础教程(7)--运算符

      现在,我们已经学会了如何声明和初始化变量,但你可能想知道如何操作它们.运算符是对一个,两个或三个操作数执行特定操作并返回结果的特殊符号.下表列出了Java中的运算符:   表格中的运算符是按照从上 ...

  5. 【SSH网上商城项目实战11】查询和删除商品功能的实现

    转自:https://blog.csdn.net/eson_15/article/details/51360804 在第8节我们完成了查询和删除商品类别的功能,那么现在实现查询和删除商品的功能就很好做 ...

  6. apache-kylin 权威指南—读书笔记

    1. 概述 kylin 是 OLAP 引擎,采用多维立方体预计算技术,可将大数据的 SQL 查询速度提升到亚秒级别. 需求: 虽然像 spark,hive 等使用 MPP 大规模并行处理和列式存储的方 ...

  7. Java 学习笔记(1)——java基础语法

    最近抽时间在学习Java,目前有了一点心得,在此记录下来. 由于我自己之前学过C/C++,而Java的语法与C/C++基本类似,所以这一系列文章我并不想从基础一点点的写,我想根据我已有的C/C++经验 ...

  8. BZOJ2229: [Zjoi2011]最小割(最小割树)

    传送门 最小割树 算法 初始时把所有点放在一个集合 从中任选两个点出来跑原图中的最小割 然后按照 \(s\) 集合与 \(t\) 集合的归属把当前集合划分成两个集合,递归处理 这样一共跑了 \(n − ...

  9. 【Android】17.0 UI开发(八)——利用RecyclerView列表控件实现精美的聊天界面

    1.0 首先新建一个项目,名叫:UIBestPractice,目录如下: 2.0 这里需要先准备两张图片,放在app\src\main\res\drawable-xhdpi目录下. 这里图片名称已经制 ...

  10. axios中设置post请求,后台却无法识别参数

    场景:在使用iview时,定义api请求时,代码如下 export const delWord = (data) => { return axios.request({ url: '/words ...