1、将函数赋值给变量

2、匿名函数

3、高阶函数

4、高阶函数的类型推断

5、Scala的常用高级函数

6、闭包

7、SAM转换

8、Currying函数

9、return

1、将函数赋值给变量

  Scala的函数是一等公民,可以独立定义,独立存在,而且可以直接将函数作为值赋值给变量。

  Scala语法规定,将函数赋值给变量时,必须在函数后面加上空格和下划线。

  

2、匿名函数

  Scala中,函数可以不需要命名,此时函数被称为匿名函数。

  可以直接定义函数后,将函数赋值给某个变量,也可以将直接定义的匿名函数传入其他函数之中。

  Scala匿名函数的语法规则是 (参数名:参数类型)=>函数体

  

3、高阶函数

  Scala中,可以直接将某个函数传入其他函数,作为参数。这个功能非常强大,java不具备这样的特性。接收其他函数作为参数的函数,也被称为高阶函数(higher-order function)。

  

  高阶函数的另外一个功能是将函数作为返回值。

  

4、高阶函数的类型推断

  高阶函数可以自动推断出参数类型,不需要写明类型;而且对于只有一个参数的函数,还可以省去其小括号。如果仅有的一个参数在右侧的函数体内只使用一次,则还可以省略接受参数,并且将参数用_来替代。

  

5、Scala的常用高级函数

  map:对传入的每个元素进行映射,返回一个处理后的元素

  foreach:对传入的每个元素都进行处理,但是没有返回值

  filter:对传入的每个元素都进行条件判断,如果对元素返回true,则保留该元素,否则过滤掉该元素。

  reduceLeft:从左侧元素开始,进行reduce操作,即先对元素1和2进行处理,然后将结果和元素3 处理,再将结果与元素4处理,依次类推,即为reduce。

  sortWith:对元素进行两两相比,进行排序

  

6、闭包

  闭包最简洁的解释:函数在变量不处于其有效作用域时,还能够对变量进行访问,即为闭包。

  

  两次调用getGreetingFunc函数,传入不同的msg,并创建不同的函数返回。

  然而,msg只是一个局部变量,却在getGreetingFunc执行完之后,还可以继续存在创建的函数中,greetingFuncHello(“LiLei”)调用时,值为hello的msg被保留在了函数体内部,可以反复的使用。这种变量超出了其作用域,还可以使用的情况,即为闭包。

  Scala通过为每个函数创建对象来实现闭包,实际上对于getGreetingFunc函数创建的函数,msg作为函数对象的变量存在的,因此每个函数才可以拥有不同的msg。

7、SAM转换

  Java中,不支持直接将函数传入一个方法作为参数,通常来说,唯一的办法就是定义一个实现了某个接口的类的实例对象,该对象只有一个方法;而这些接口都只有单个的抽象方法,也就是single abstract method,简称SAM。

  由于Scala可以调用Java代码的,因此当我们调用java的某个方法时,就不得不创建SAM传递给方法,非常麻烦;但是Scala又是支持直接传递函数的。此时就可以使用Scala提供的,在调用java方法时,使用的功能,SAM转换,即将SAM转换为Scala函数。

  要使用SAM转换,需要使用Scala提供的特性,隐式转换。

  

8、Currying函数

  Curring函数,是指将原来接受两个参数的一个函数,转换为两个函数,第一个函数接受原来的第一个参数,然后返回接受原来第二个参数的第二个函数。

  

9、return

  Scala中,不需要使用return来返回函数的值,函数最后一行语句的值就是函数的返回值。

  return用于在匿名函数中返回值给包含匿名函数的带名函数,并作为带名函数的返回值。

  使用return的匿名函数,是必须给出返回类型的,否则无法通过编译。

  

11、scala函数式编程的更多相关文章

  1. Scala函数式编程(三) scala集合和函数

    前情提要: scala函数式编程(二) scala基础语法介绍 scala函数式编程(二) scala基础语法介绍 前面已经稍微介绍了scala的常用语法以及面向对象的一些简要知识,这次是补充上一章的 ...

  2. Scala函数式编程(六) 懒加载与Stream

    前情提要 Scala函数式编程指南(一) 函数式思想介绍 scala函数式编程(二) scala基础语法介绍 Scala函数式编程(三) scala集合和函数 Scala函数式编程(四)函数式的数据结 ...

  3. Scala函数式编程进阶

    package com.dtspark.scala.basics /** * 函数式编程进阶: * 1,函数和变量一样作为Scala语言的一等公民,函数可以直接赋值给变量: * 2, 函数更长用的方式 ...

  4. Scala函数式编程——近半年的痛并快乐着

    从9月初啃完那本让人痛不欲生却又欲罢不能的<七周七并发模型>,我差不多销声匿迹了整整4个月.这几个月里,除了忙着讨食,便是继续啃另一本"锯著"--<Scala函数 ...

  5. Scala实战高手****第5课:零基础实战Scala函数式编程及Spark源码解析

    Scala函数式编程 ----------------------------------------------------------------------------------------- ...

  6. 9、scala函数式编程-集合操作

    一.集合操作1 1.Scala的集合体系结构 // Scala中的集合体系主要包括:Iterable.Seq.Set.Map.其中Iterable是所有集合trait的根trai.这个结构与Java的 ...

  7. Scala函数式编程(四)函数式的数据结构 上

    这次来说说函数式的数据结构是什么样子的,本章会先用一个list来举例子说明,最后给出一个Tree数据结构的练习,放在公众号里面,练习里面给出了基本的结构,但代码是空缺的需要补上,此外还有预留的test ...

  8. Scala函数式编程(四)函数式的数据结构 下

    前情提要 Scala函数式编程指南(一) 函数式思想介绍 scala函数式编程(二) scala基础语法介绍 Scala函数式编程(三) scala集合和函数 Scala函数式编程(四)函数式的数据结 ...

  9. scala 函数式编程之集合操作

    Scala的集合体系结构 // Scala中的集合体系主要包括:Iterable.Seq.Set.Map.其中Iterable是所有集合trait的根trai.这个结构与Java的集合体系非常相似. ...

  10. 大数据笔记(二十五)——Scala函数式编程

    ===================== Scala函数式编程 ======================== 一.Scala中的函数 (*) 函数是Scala中的头等公民,就和数字一样,可以在变 ...

随机推荐

  1. 夜话JAVA设计模式之单例模式(单件模式Singleton)

    单例模式也叫单件模式,就是确保一个类只有一个实例,并提供一个全局访问点. 设计成单例即把某个类设计成我们自己管理的单独实例,避免实例对象的重复创建,我们只有通过单例类的全局访问点获取实例. 下面来看金 ...

  2. 两张图让git新手在项目中运用git命令行

    创建分支命令:    git branch (branchname) 切换分支命令:      git checkout (branchname) 当你切换分支的时候,Git 会用该分支的最后提交的快 ...

  3. C#: 旋转图片到正确位置

    当从iPhone等手机上传图片到服务器后,通常需要进行旋转处理,否则在进行图片压缩.缩放处理后会丢失正确的位置信息,导致显示的图片不处于正确的位置上. 处理的做法就是读取照片的Exif信息,并旋转到正 ...

  4. load函数

    load函数的作用 1.load函数的作用是,从server获取数据,而且把数据放到指定的元素(通常是div元素)中. 2.说的再具体一些就是,把获取到的数据插入到当前文档的某个div元素中. ser ...

  5. javascript 中文与Unicode相互转化

      javascript 中文与Unicode相互转化 CreateTime--2018年3月30日11:26:50 Author:Marydon /** * 中文与Unicode的相互转换 */ v ...

  6. Ubuntu下安装C/C++开发环境【!!!有更新!!!Ubuntu14.10下使用eclipse搭建C语言开发环境】

    (1)第一步安装Eclipse,有两种方法,使用软件市场搜索就可以得到,安装就可以 另外一种是使用终端安装,命令例如以下: sudo su进入root模式 输入password 然后 输入:sudo ...

  7. docker(1):virtualbox 安装CoreOS系统,配置registry-mirror

    本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/51093850 未经博主同意不得转载. 博主地址是:http://blog.csd ...

  8. git-svn for mac

    熟练使用 git ,新公司用的是 svn,这就尴尬了,为了这个习惯问题,我还是毅然坚持使用 git,但是又不与公司的 svn 冲突,所以就找到了 git 的 git-svn 插件. 在 mac 上使用 ...

  9. 嵌入式C语言经常使用keyword

    1.statickeyword 这个keyword前面也有提到.它的作用是强大的. 要对statickeyword深入了解.首先须要掌握标准C程序的组成. 标准C程序一直由下列部分组成:       ...

  10. cached

    /proc/sys/vm/ 关于Linux cached内存简析 - CSDN博客 http://blog.csdn.net/fox_hacker/article/details/41351687 [ ...