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. 【根文件系统 】开发板通过nfs挂载ubuntu上的根文件系统

    在此基础上制作可用的根文件系统:https://www.cnblogs.com/hengqiu/p/15908597.html 1.ubuntu搭建nfs服务器 sudo apt-get instal ...

  2. python peewee

    from peewee import MySQLDatabase, Model from peewee import CharField, IntegerField, BooleanField # 引 ...

  3. 树莓派 Zero W 安装 apache2 + php

    ※ 树莓派Zero W ,默认 hostname为 raspberrypi ,通过USB网络方式登陆时,修改hostname后,登录主机名要随之变化. ① ssh pi@raspberrypi 更新系 ...

  4. 其他计算机&网络&行业知识

    互联网数据中心(IDC)   VIDC(端口映射) CVM云服务器(Cloud Virtual Machine)  IDE 集成开发环境: 开发工具 QA:Quality Assurance,直译为质 ...

  5. 第一次写,python爬虫图片,操作excel。

    第一次写博客,其实老早就注册博客园了,有写博客的想法,就是没有行动,总是学了忘,忘了丢,最后啥都没有,电脑里零零散散,东找找,西看看,今天认识到写博客的重要性. 最近闲着看了潭州教育的在线直播课程,颇 ...

  6. JVM中类加载子系统

    1.类加载子系统中有哪些常用类加载器? 1.BootStrapClassLoader(负责加载基础类库中的类,例如Object,String....) 2.ExtClassLoader(负责加载扩展类 ...

  7. ssh 远程报错 Permission denied, please try again.(密码输入正确也无法登录)

    登录KVM  查看sshd服务systemctl  status sshd 报错显示error: cloud not get  shadow  information forXXX 问题原因: 服务器 ...

  8. 路由器、集线器、交换机分别工作在OSI七层协议模型的哪一层

    路由器三层(网络层): 集线器一层(物理层): 普通交换机二层(数据链路层). 现在也有工作在第三层的交换机. OSI七层网络模型由下至上为1至7层,分别为物理层(Physical layer),数据 ...

  9. vue页面点击按钮增加和删除标签

    1.在data()里定义一个空数组: conditions:[], 2.给数组一个容器,并且遍历数组 <div v-for="item in conditions">& ...

  10. XSS - Cross Site Scripting

    origin url: https://www.synopsys.com/glossary/what-is-csrf.html#:~:text=Definition,has in an authent ...