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之函数式编程的更多相关文章

  1. Scala:函数式编程之下划线underscore

    http://blog.csdn.net/pipisorry/article/details/52913548 python参考[python函数式编程:apply, map, lambda和偏函数] ...

  2. Scala函数式编程进阶

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

  3. Scala入门系列(九):函数式编程

    引言 Scala是一门既面向对象,又面向过程的语言,Scala的函数式编程,就是Scala面向过程最好的佐证.也真是因此让Scala具备了Java所不具备的更强大的功能和特性. 而之所以Scala一直 ...

  4. Scala入门系列(十):函数式编程之集合操作

    1. Scala的集合体系结构 Scala中的集合体系主要包括(结构跟Java相似): Iterable(所有集合trait的根trait) Seq(Range.ArrayBuffer.List等) ...

  5. 5. Scala函数式编程的基础

    5.1 函数式编程内容及介绍顺序说明 5.1.1 函数式编程内容 -函数式编程基础 函数定义/声明 函数运行机制 递归(难点,[最短路径,邮差问题,迷宫问题,回溯]) 过程 惰性函数和异常 -函数式编 ...

  6. Scala学习教程笔记三之函数式编程、集合操作、模式匹配、类型参数、隐式转换、Actor、

    1:Scala和Java的对比: 1.1:Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象,而且只 ...

  7. Scala学习教程笔记二之函数式编程、Object对象、伴生对象、继承、Trait、

    1:Scala之函数式编程学习笔记: :Scala函数式编程学习: 1.1:Scala定义一个简单的类,包含field以及方法,创建类的对象,并且调用其方法: class User { private ...

  8. (数据科学学习手札48)Scala中的函数式编程

    一.简介 Scala作为一门函数式编程与面向对象完美结合的语言,函数式编程部分也有其独到之处,本文就将针对Scala中关于函数式编程的一些常用基本内容进行介绍: 二.在Scala中定义函数 2.1 定 ...

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

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

  10. 8、scala函数式编程

    一.函数式编程1 1.介绍 Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象, 而且只有方法的概念 ...

随机推荐

  1. 在 Windows 上使用VirtualBox 安装 Ubuntu

    一.VirtualBox虚拟机软件 之前使用过VMWare,这是第一次尝试使用VirtualBox,记录一下~ 我们可以从官网下载VirtualBox,地址:https://www.virtualbo ...

  2. Installing Jupyter

    https://jupyter.org/install install pip install jupyterlab config 生成配置文件 jupyter notebook --generate ...

  3. java写 变量到文件

    import java.io.BufferedReader; import java.io.File;import java.io.FileReader; import java.io.IOExcep ...

  4. 批量获取title

    1 import requests 2 from bs4 import BeautifulSoup 3 import pandas as pd 4 from openpyxl import Workb ...

  5. [MySQL高级](一) EXPLAIN用法和结果分析

    转载自: https://blog.csdn.net/why15732625998/article/details/80388236

  6. py06

    元祖tuple 与列表类似可以存多个值,但是不同的是元祖本身不能被修改 #一:基本使用:tuple# 1 用途:记录多个值,当多个值没有改的需求,此时用元组更合适 # 2 定义方式:在()内用逗号分隔 ...

  7. vscode远程连接服务器出现Bad owner or permissions on .ssh/config

    vscode远程连接服务器出现Bad owner or permissions on C:\\Users\USER\.ssh/config 过程试图写入的管道不存在, 原因是vscode的remoto ...

  8. 新建zabbix数据库

    1.安装mysqldnf install -y @mysqlsystemctl start mysqld.servicesystemctl enable mysqld.service初始化mysqlm ...

  9. PMP项目启动会与开工会议

    转载https://www.cnblogs.com/yanpeng1991/p/11391805.html 项目启动会(project initiating meeting)与项目开工会(kick-o ...

  10. python--线性回归

    首先先安装要用到的包:sklearn,顾名思义机器学习包 import matplotlib.pyplot as plt import numpy as np import pandas as pd ...