【Scala】用实例弄清楚scala几种函数的定义和特点
文章目录
作为参数的函数
scala> val a1 = Array(1,2,3,4) //这是一个数组
a1: Array[Int] = Array(1, 2, 3, 4)
scala> val f1 = (x:Int) => x * 2 //这是一个函数,命名f1
f1: Int => Int = <function1>
scala> a1.map(f1) //函数f1可以作为参数使用
res6: Array[Int] = Array(2, 4, 6, 8)
匿名函数
scala> val a1 = Array(1,2,3,4)
a1: Array[Int] = Array(1, 2, 3, 4)
scala> a1.map((x:Int) => x * 2) //不给其命名,直接使用称为匿名函数
res7: Array[Int] = Array(2, 4, 6, 8)
柯里化函数(currying)
柯里化(Currying) 是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。
通俗且不严谨地来说,柯里化函数就是把一个函数的多参数列表拆分为多个单参数列表
//按通常的方法以及调用是下面这样
scala> def m1(x:Int,y:Int) = x+y
m1: (x: Int, y: Int)Int
scala> m1(2,3)
res8: Int = 5
//柯里化函数
scala> def m2(x:Int)(y:Int) = x+y
m2: (x: Int)(y: Int)Int
scala> m2(2)(3) //柯里化函数这样可以应对一些情况
res10: Int = 5 //比如方法需要拿到两个参数但只拿到一个参数
//实际上就是执行了两次函数调用
scala> m2(2)_
res11: Int => Int = <function1> //m2(2)_会返回一个函数
//调用的时候这样用即可
scala> res11(3)
res12: Int = 5
//可以多次调用,不是一次性的
scala> res11(7)
res13: Int = 9
//柯里化函数的运行机制就像下面这样
scala> def m3(x:Int) = (y:Int) => x+y
m3: (x: Int)Int => Int
scala> m3(2)
res14: Int => Int = <function1>
scala> res14(3)
res15: Int = 5
闭包函数
闭包就是能够读取其他函数内部变量的函数,也可以认为是对自由变量的捕获
scala> var y = 5 //定义一个变量
y: Int = 5
scala> def m1(x:Int) = x+y //这里只给出了一个参数,但方法是x+y两个参数
m1: (x: Int)Int
scala> m1(2) //可以看出这里直接捕获了y变量的值
res16: Int = 7
scala> var y = 2
y: Int = 2
scala> m1(2) //但不会因为变量值的修改而更改
res17: Int = 7
【Scala】用实例弄清楚scala几种函数的定义和特点的更多相关文章
- javascript基础之两种函数的定义方法
第一种方式:可以在函数定义之前调用也可以在函数定义之后调用: (0)函数的调用 add(,) //可以调用 (1)函数的定义: function add(x,y) { console.log(x+y) ...
- Scala编程实例:使用List和Tuple
本文节选自Martin Odersky,Lex Spoon和Bill Venners所著,Regular翻译的<Programming in Scala>的第三章.Scala是一种针对 J ...
- SCALA编程实例
SCALA与JAVA很相似,包括类.函数.集合等等的使用.如果你是一个JAVA程序员,你应该会很快上手. 需要注意的是SCALA特有的一些奇葩标志,比如->,比如=>,遇到要注意下. 使用 ...
- Scala 编程(一)Scala 编程总览
Scala 简介 Scala 属于“可伸展语言”,源于它可以随使用者的需求而改变和成长.Scala 可以应用在很大范围的编程任务上,小到脚本大到建立系统均可以. Scala 跑在标准 Java 平台上 ...
- Scala教程之:面向对象的scala
文章目录 面向对象的scala Unified Types Classes Traits 面向对象的scala 我们知道Scala是一种JVM语言,可以合java无缝衔接,这也就大大的扩展了scala ...
- [大数据从入门到放弃系列教程]在IDEA的Java项目里,配置并加入Scala,写出并运行scala的hello world
[大数据从入门到放弃系列教程]在IDEA的Java项目里,配置并加入Scala,写出并运行scala的hello world 原文链接:http://www.cnblogs.com/blog5277/ ...
- Scala系统学习(四):Scala变量
变量是保存存储值的内存位置的名称.这意味着当创建变量时,可以在内存中保留一些空间. 根据变量的数据类型,编译器分配内存并决定可以存储在预留内存中的内容.因此,通过为变量分配不同的数据类型,可以在这些变 ...
- Scala系统学习(一):Scala概述
Scala是可扩展语言的缩写,是一种混合功能编程语言. 它由Martin Odersky创建. Scala顺利整合面向对象和函数式语言的功能. Scala被编译后在Java虚拟机上运行. 许多现有公司 ...
- Scala 系列(一)—— Scala 简介及开发环境配置
一.Scala简介 1.1 概念 Scala 全称为 Scalable Language,即"可伸缩的语言",之所以这样命名,是因为它的设计目标是希望伴随着用户的需求一起成长.Sc ...
随机推荐
- Delphi TMemo 可以显示、编辑多行文本
多行编辑框组件(TMemo)TMemo组件可以显示.编辑多行文本,是一个标准的Windows多行编辑组件.对一些比较多的文本内容可以利用TMemo组件来显示.编辑. 1.TMemo组件的典型用法 TM ...
- 8行代码帮你python建立UDP通信
首先我们要搭建一个UDP通信,首先我们就要知道什么UDP: UDP用户数据报传输协议,它位于TCP/IP协议的传输层,是一种无连接的协议,它发送的报文不能确定是否完整地到达了另外一端.UDP广泛应用于 ...
- 牛客练习赛61 相似的子串(二分+Hash)
题面在此 题解:将字符串分成k部分,然后求最长前缀,所以我们只关注前缀部分就好了,公共前缀后边的是啥不用管,那么问题就转化成了是否存在k个不相交的字符串的最长公共前缀问题.首先用Hash来记录一下字符 ...
- B - Red and Black 直接BFS+队列
There is a rectangular room, covered with square tiles. Each tile is colored either red or black. A ...
- 落谷 P1734 最大约数和
题目描述 选取和不超过S的若干个不同的正整数,使得所有数的约数(不含它本身)之和最大. 输入格式 输入一个正整数S. 输出格式 输出最大的约数之和. 输入输出样例 输入 #1复制 11 输出 #1复制 ...
- 带权值的图 BFS
用bfs遍历最图求最短路径时通常借用优先队列即优先考虑最大的或者最小的权值 方法1 优先队列:(内置函数,优先考虑较小的权值) #include<iostream> #include< ...
- 统计字符串中每种字符出现的评率(HashMap中getOrDefault(K, V)方法的使用)
为了统计字符串中每种字符出现的频率,使用HashMap这种数据结构.其中,字符作为Key,出现的频率作为Value. 基本算法为: 1. 将字符串分成字符数组 2. (1)如果HashMap中的Key ...
- 如何在非 sudo 用户下运行 docker 命令?
当我们在一台 Linux 系统中安装了 Docker 后, 有时候会遇到下面这样的错误, 我们在运行 docker 的命令时必须加上 sudo, 例如: sudo docker ps, 但是我们其实更 ...
- pytorch中tensor张量的创建
import torch import numpy as np print(torch.tensor([1,2,3])) print(torch.tensor(np.arange(15).reshap ...
- Spring5参考指南:SpringAOP简介
文章目录 AOP的概念 Spring AOP简介 Spring AOP通知类型 写过程序的都知道OOP即面向对象编程. 从最开始的面向过程编程,到后面的面向对象编程,程序的编写方式发生了重大的变化,面 ...