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中的一等公民是类和对象, 而且只有方法的概念 ...
 
随机推荐
- 我们后端代码这样子设置虽然这样子返回的是字符串,但是json字符串也是字符串
			
我们后端代码这样子设置虽然这样子返回的是字符串 但是json字符串也是字符串,后端如果想接收的话,直接百度下怎么接收json字符串就行
 - Vue 数组响应
			
响应渲染 在Vue中,被渲染的数据都是响应式的,即Vue实例中进行改变页面中也会跟着改变: <body> <div id="app"> <p>{ ...
 - php集成环境包PhpStudy及部署网站
			
一.介绍: phpStudy 是一个PHP调试环境的程序集成包. 该程序包集成最新的Apache+PHP+MySQL+phpMyAdmin+ZendOptimizer,一次性安装,无须配置即可使用, ...
 - YOLOV4网络
			
Yolov4网络代码 from collections import OrderedDict import torch import torch.nn as nn from Darknet_53 im ...
 - python中items()和iteritems()的区别
			
items()函数,将一个字典以dict_items的形式返回,因为字典是无序的,所以返回的列表也是无序的: 1 a ={'a':1,'b':2,'c':3,'d':4} 2 print(a.item ...
 - win10关闭自动更新的方法
			
win10关闭自动更新的方法和步骤: 一.禁用Windows Update服务 1.打开服务项,win+r 输入 services.msc ,或者控制面板-管理工具-服务. 2.找到 Windows ...
 - k8s_使用k8s部署博客系统-PV PVC(二)
			
PV和PVC PV(PersistentVolume)在声明的时候需要指定大小和续写模式:["ReadWriteMany","ReadWriteOnce",&q ...
 - vue IE9兼容flex布局 css3(转载)
			
原文 https://blog.csdn.net/shihezhengshz/article/details/118860562 写这文章的时候的我,心力憔悴鸭,找了好长时间,呜呜┭┮﹏┭┮ 好了,开 ...
 - VUE前端请求跨域问题解决
			
解决方法: vue.config.js文件配置: module.exports = { devServer: { open: true, host: '192.168.1.193', port: 80 ...
 - 记下HTML中图片的路径
			
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 < ...