scala之函数式编程
1、面相对象编程和函数式编程

2、函数和方法的区别

scala可以在任何的语法结构中声明任何的语法;
scala中函数可以嵌套定义;
scala中如果main内部的函数 和 main外部的函数名称、参数、返回值均一样时,
此时main内部的函数优先被调用;
3、函数的参数
(1 ) 可变参数:当前参数的个数可以不确定;

(2) 如果参数列表中存在多个参数,那么可变参数一般放置在最后;

(3) 参数默认值,一般将有默认值的参数放在参数列表的后面;
被指定默认值的参数在调用函数时可以不传该参数;

(4) 带名参数;

4、函数至简原则(能省则省)
(1) return可以省略,scala会使用函数体的最后一行代码作为返回值;
(2) 如果函数体只有一行代码,花括号可以省略;
(3) 返回值类型如果能够推断出来,那么:和 返回值类型 可以一起省略;
例如:def function3(name: String) = name
(4) 如果有return,则返回值类型不能省略,必须指定;
(5) 如果函数明确声明Unit,那么函数体中即使使用return关键字,也不起作用;
(6) scala中如果期望是无返回值类型,可以省略等号;

(7) 如果函数无参,但是声明了参数列表,那么调用时,小括号可加可不加;

(8) 如果函数没有参数列表,那么小括号可以省略,调用时小括号必须省略;

(9) 如果不关心当前函数的名称,只关心逻辑处理,那么函数名(def)可以省略;

注意:def省略后的函数被成为 匿名函数,lambda表达式
5、匿名函数
(1 ) 匿名函数的调用: 将整个函数的值赋给变量;

(2) 匿名函数的简化原则
a、参数的类型可以省略,会根据形参进行自动的推导;
b、类型省略之后,发现只有一个参数,则圆括号可以省略;
其他情况:没有参数或参数超过1的永远不能省略圆括号;
c、如果匿名函数的函数体只有一行,则大括号也可以省略;
d、如果参数只出现一次,则参数省略且后面参数可以用_替代;
e、如果可以推断出,当前传入的println是一个函数体,而不是调用语句,可以直接省略下划线;

(3) 匿名函数的应用
a、应用1:以函数作为参数输入:此时的函数可以称为是一种操作;

println(dualEval( _ + _ , 23 , 44 )) //可以再进一步进行简化
b、应用2:函数可以作为值传递

c、应用3:函数可以作为函数返回值返回

6、scala递归实现阶乘

缺点:耗费很多栈空间资源,可能会出现栈内存溢出。
// 计算f5的数据时,f(5)/f(4)/f(3)...f(1)的数据均存储在栈针中。

7、控制抽象--针对函数参数
值调用:传值参数

名调用:传名参数

8、闭包和柯里化
(1)、闭包:如果一个函数访问到了它的外部(局部)变量的值,那么这个函数和他所处的环境,成为闭包。
闭包是函数,它的返回值取决于此函数之外声明一个或多个变量的值。
目的:把内层函数所依赖的变量给保存起来,延长变量的生命周期,保证我们调用时能找到。
实现方式:外层函数 要以内层函数作为返回值 来返回。
(以一个内层函数作为返回值,来定义一个外层函数:内层函数用到了外层函数的变量/参数)
闭包实例

(2)、函数柯里化:把一个参数列表的多个参数,变成多个参数列表(更常用)。
注意:柯里化的底层一定是闭包;闭包并非要用柯里化去书写。

小扩展:
JVM中: 所有使用的对象 是存储在heap堆(堆本身线程是共享的)中,
所有的局部变量和操作数 存在stack栈(栈本身线程是独享的)中
scala之函数式编程的更多相关文章
- Scala:函数式编程之下划线underscore
http://blog.csdn.net/pipisorry/article/details/52913548 python参考[python函数式编程:apply, map, lambda和偏函数] ...
- Scala函数式编程进阶
package com.dtspark.scala.basics /** * 函数式编程进阶: * 1,函数和变量一样作为Scala语言的一等公民,函数可以直接赋值给变量: * 2, 函数更长用的方式 ...
- Scala入门系列(九):函数式编程
引言 Scala是一门既面向对象,又面向过程的语言,Scala的函数式编程,就是Scala面向过程最好的佐证.也真是因此让Scala具备了Java所不具备的更强大的功能和特性. 而之所以Scala一直 ...
- Scala入门系列(十):函数式编程之集合操作
1. Scala的集合体系结构 Scala中的集合体系主要包括(结构跟Java相似): Iterable(所有集合trait的根trait) Seq(Range.ArrayBuffer.List等) ...
- 5. Scala函数式编程的基础
5.1 函数式编程内容及介绍顺序说明 5.1.1 函数式编程内容 -函数式编程基础 函数定义/声明 函数运行机制 递归(难点,[最短路径,邮差问题,迷宫问题,回溯]) 过程 惰性函数和异常 -函数式编 ...
- Scala学习教程笔记三之函数式编程、集合操作、模式匹配、类型参数、隐式转换、Actor、
1:Scala和Java的对比: 1.1:Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象,而且只 ...
- Scala学习教程笔记二之函数式编程、Object对象、伴生对象、继承、Trait、
1:Scala之函数式编程学习笔记: :Scala函数式编程学习: 1.1:Scala定义一个简单的类,包含field以及方法,创建类的对象,并且调用其方法: class User { private ...
- (数据科学学习手札48)Scala中的函数式编程
一.简介 Scala作为一门函数式编程与面向对象完美结合的语言,函数式编程部分也有其独到之处,本文就将针对Scala中关于函数式编程的一些常用基本内容进行介绍: 二.在Scala中定义函数 2.1 定 ...
- 9、scala函数式编程-集合操作
一.集合操作1 1.Scala的集合体系结构 // Scala中的集合体系主要包括:Iterable.Seq.Set.Map.其中Iterable是所有集合trait的根trai.这个结构与Java的 ...
- 8、scala函数式编程
一.函数式编程1 1.介绍 Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象, 而且只有方法的概念 ...
随机推荐
- Java基础——IO模型详解
- 1067- invalid default value for ""
创建表时报的,一个时间字段类型是datetime,一保存就报错,网上说是datetime类型只支持mysql 5.6.5+,我看了下我的版本,5.8的,没什么问题,然后找了许久找到了错误的地方. 很蠢 ...
- WPF materialDesign 锁屏后界面卡死问题解决
materialDesign的一个缓存机制问题,在xaml文件中Window属性添加一行: materialDesign:ShadowAssist.CacheMode="{x:Null}&q ...
- (Yocto)Imx8mp的时间结构
1.构成图 #kernel\time\timekeeping.c #drivers\rtc\class.c 1.time date source 解释 rx8010sj: 自己定制的开发板 ...
- supertv
Banben:1.3BanbenendGengxinnr:死宅1.2更新内容:[换行]- 增加视频分享[换行]- 支持浏览器打开观看视频GengxinnrendDownurl:http://bmob- ...
- maven静态资源过滤
<resources> <resource> <directory>src/main/java</directory> <includes> ...
- UI基础 - UIAppearance协议
前言 1 - 在一些 app 中会涉及到更改外观设置的功能,最普遍的就是夜间模式和白天模式的切换,而对于外观的更改必定是一个全局的东西.这在 iOS5 以前想要实现这样的效果是比较困难的,但是 iOS ...
- 从零搭建hadoop集群之节点间免密登录
我这里有三台虚拟机 分别是 hadoop01 hadoop02 hadoop03 1.所有节点切入到hadoop用户 2.分别再三个节点上输入 ssh-keygen 命令(输入命令后敲回车键三下) ...
- javascript【应用】debounce和throttle
debounce防抖 在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时:典型的案例就是输入搜索:输入结束后n秒才进行搜索请求,n秒内又输入的内容,就重新计时. <div id=& ...
- R6-1 输入年份和天数,输出对应的年、月、日
R6-1 输入年份和天数,输出对应的年.月.日 分数 15 全屏浏览题目 切换布局 作者 张泳 单位 浙大城市学院 要求定义和调用函数month_day ( year, yeardy, *****pm ...