Scala高阶函数
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高阶函数的更多相关文章
- scala高阶函数类型推断什么时候失效?
class TypeInfer(self: Int, other: Int) { def test(num: Int, word: String, fun1: (Int, Int) => Int ...
- Scala高阶函数与泛型
1. Scala中的函数 在Scala中,函数是“头等公民”,就和数字一样.可以在变量中存放函数,即:将函数作为变量的值(值函数). 2. scala中的匿名函数,即没有函数名称的函数,匿名函数常作为 ...
- Scala高阶函数实践
高阶函数主要有两种:一种是将一个函数当做另外一个函数的参数(即函数参数):另外一种是返回值是函数的函数.package sparkCore/** * Created by zhen on 2018/3 ...
- Scala高阶函数示例
object Closure { def function1(n: Int): Int = { val multiplier = (i: Int, m: Int) => i * m multip ...
- Scala中的构造器和高阶函数
构造器 在定义类时可以定义主构造器.主构造器可以同时声明字段. /** * 主构造器 * @author Administrator */ //在scala中,类和方法交织在一起 class Test ...
- Thinking in scala (6)----高阶函数----返回一个函数
在Thinking in scala (5)----高阶函数* 里面,我们演示了如何把一个函数作为参数传递给另外一个函数. 在本文里面,我们来演示函数式编程另外一个重要的特性:返回一个函数.首先来看这 ...
- Thinking in scala (5)----高阶函数*
高阶函数是函数式编程里面一个非常重要的特色,所谓的高阶函数,就是以其它函数作为参数的函数. 下面以一个小例子演示Scala的高阶函数特性,非常有意思,也非常强大. 首先看这么一个程序: code1: ...
- Scala - 快速学习08 - 函数式编程:高阶函数
函数式编程的崛起 函数式编程中的“值不可变性”避免了对公共的可变状态进行同步访问控制的复杂问题,能够较好满足分布式并行编程的需求,适应大数据时代的到来. 函数是第一等公民 可以作为实参传递给另外一个函 ...
- spark快速开发之scala基础之5高阶函数,偏函数,闭包
高阶函数 高阶函数就是将函数作为参数或者返回值的函数. object function { def main(args: Array[String]): Unit = { println(test(f ...
随机推荐
- 【总结】java 后台文件上传整理
public Map<String,String> clientUploadAttachment(Long belongId, String fileSource, MultipartFi ...
- JavaScript的柯里化函数
柯里化,或者说部分应用,是一种函数式编程的技术,对于熟悉以传统方式编写 JavaScript 代码的人来说可能会很费解.但如果使用得当,它可以使你的 JavaScript 函数更具可读性. 更具可读性 ...
- EF Code-First数据迁移
Code-First数据迁移 首先要通过NuGet将EF升级至最新版本. 新建MVC 4项目MvcMigrationDemo 添加数据模型 Person 和 Department,定义如下: usi ...
- NSURLSession和NSURLConnection
iOS9.0之后NSURLConnection被注销,采用NSURLSession,先介绍NSURLSession,然后介绍NSURLConnection 1.NSURLSession: post请求 ...
- linux ssh免密登陆
大致流程: 两台linux系统A B 如果A要登陆到B 1.生成A的密钥对 2.将A的公钥拷贝到B的authorized_keys中即可 可以使用命令:ssh-copy-id -i ~/.ssh/id ...
- JDBC入门(3)--- PrepareStatement
一.PrepareStatement概述 PrepareStatement是Statement接口的子接口: 1.强大之处: 防SQL攻击: 提高代码的可读性: 提高效率; 2.PrepareStat ...
- 在弹框中获取foreach中遍历的id值,并传递给地址栏(方法2)
1.php有时候我们需要再弹框中获取foreach中遍历的数据(例如id),在弹框中点击按钮并传递给地址栏跳转.那么应该怎么做呢.第二种方法. 2. 可以在弹框中给出一个input hidden 点击 ...
- Windows下多个JDK版本之间的切换
一.JDK版本切换批处理脚本 我们平时在window上做开发的时候,可能需要同时开发两个甚至多个项目,有时不同的项目对JDK的版本要求有区别,这时候我们可能会在一台电脑上安装多个版本的JDK,如下 ...
- js点击事件在苹果端失效的问题
在安卓机上,我们随意定义点击事件也能够在找到点击的元素,但是在苹果端上就是不行,怎么点击都没有效果.这是因为在苹果机上window禁止了手指误点功能,必须解除这一功能,或者给点击事件指引某个元素上绑定 ...
- C#-求int数组中连续偶数列的个数
例如:[3, 3, 2, 2, 2, 4, 3, 5, 4, 6, 3]=>2,2,2,4;4,6 结果为2 [3, 3, 2,3, 2, 2, 4, 3, 5, 4, 6, 3]=&g ...