模式匹配

使用用模式匹配实现斐波那契

def fibonacci(in: Any): Int = in match {
case 0 => 0
case 1 => 1
case n: Int if(n > 1)=> fibonacci(n - 1) + fibonacci(n - 2)
case _ => 0
} println(fibonacci(3))

元组tuple

元组可以保存不同类型的值,不能通过名称获取字段,而是使用位置下标来读取对象;而且这个下标基于1,而不是基于0。

val hostPort = ("localhost", 80)
println("host:%s,port:%s".format(hostPort._1,hostPort._2))

执行结果:

host:localhost,port:80

选项 Option

Option 是一个表示有可能包含值的容器。

Option基本的接口是这样的:

trait Option[T] {
def isDefined: Boolean
def get: T
def getOrElse(t: T): T
}

映射 Map

Option本身是泛型的,并且有两个子类: Some[T] 或 None

Map.get 使用 Option 作为其返回值,表示这个方法也许不会返回你请求的值。

val map = Map(1 -> "one", 2 -> "two")
println(map.get(2))
println(map.get(3))

执行结果:

Some(two)
None

函数组合子(Functional Combinators)

map

map对列表中的每个元素应用一个函数,返回应用后的元素所组成的列表。

    val numbers = List(1, 2, 3)
val double = numbers.map((i: Int) => i * 2)
val squared = numbers.map((i: Int) => BigInt(i).pow(3))
println("%s".format(numbers))
println(double)
println(squared)
//传入一个部分应用函数
def timesTwo(i: Int): Int = i * 2
val doubleFunction = numbers.map(timesTwo _)
println(doubleFunction)

执行结果:

List(1, 2, 3)
List(2, 4, 6)
List(1, 8, 27)
List(2, 4, 6)

foreach

foreach很像map,但没有返回值。foreach仅用于有副作用[side-effects]的函数

    //foreach返回值为Unit即void
val foreachResult = numbers.foreach { (i: Int) => i * 2 }
println(foreachResult)

执行结果:

()

filter

filter移除任何对传入函数计算结果为false的元素

    val filterResult = numbers.filter { (i: Int) => i % 2 == 0 }
println(filterResult)

执行结果:

List(2)

zip

zip将两个列表的内容聚合到一个对偶列表中,多余的元素删除

    val zipResult = numbers.zip(List('a', 'b', 'c', 'd'))
println(zipResult)

执行结果:

List((1,a), (2,b), (3,c))

partition

partition将使用给定的谓词函数分割列表。

    val partitionResult = numbers.partition { _ % 2 == 0 }
println("partition result:%s".format(partitionResult))

执行结果:

partition result:(List(2),List(1, 3))

find

find返回集合中第一个匹配谓词函数的元素

    var findResult = numbers.find(_ == 1)
println("find result:%s".format(findResult))
findResult = numbers.find(_ > 3)
println("find result:%s".format(findResult))

执行结果:

find result:Some(1)
find result:None

drop&dropWhile

drop删除前i个元素,dropWhile删除直到不满足谓词函数的元素

    var dropResult = numbers.drop(2)
println("drop result:%s".format(dropResult))
dropResult = numbers.dropWhile(_ % 2 != 0)
println("dropWhile result:%s".format(dropResult))

执行结果:

drop result:List(3)
dropWhile result:List(2, 3)

foldLeft&foldRight

0为初始值(记住numbers是List[Int]类型),m作为一个累加器,foldRight与foldLeft运行过程相反

    var foldLeftResult = numbers.foldLeft(0) {
(m: Int, n: Int) => println("m:" + m + " n:" + n); m + n
}
println("foldLeft result:%s".format(foldLeftResult))
var foldRightResult = numbers.foldRight(0) {
(m: Int, n: Int) => println("m:" + m + " n:" + n); m + n
}
println("foldRight result:%s".format(foldRightResult))

执行结果:

m:0 n:1
m:1 n:2
m:3 n:3
foldLeft result:6
m:3 n:0
m:2 n:3
m:1 n:5
foldRight result:6

flatten

flatten将嵌套结构扁平化为一个层次的集合

    var flattenResult = List(List(1, 2, 3), List(4, 5, 6)).flatten
println("flatten result:%s".format(flattenResult))

执行结果:

flatten result:List(1, 2, 3, 4, 5, 6)

flatMap

flatMap是一种常用的组合子,结合映射[mapping]和扁平化[flattening]。 flatMap需要一个处理嵌套列表的函数,然后将结果串连起来。flatMap是map和flatten的组合。

    val nestedNumbers = List(List(1, 2), List(3, 4))
var flatMapResult = nestedNumbers.flatMap(x => x.map(_ * 2))
println("flatMap result:%s".format(flatMapResult))
flatMapResult = nestedNumbers.map(x => x.map(_ * 2)).flatten
println("flatMap result:%s".format(flatMapResult))

执行结果:

flatMap result:List(2, 4, 6, 8)
flatMap result:List(2, 4, 6, 8)

广告

点击Spark加入群Spark,分享更多Spark相关信息

Scala快速入门-基本数据结构的更多相关文章

  1. Scala快速入门到精通 视频教程 百度云网盘下载地址

    Scala快速入门到精通  视频教程 百度云网盘下载地址 Scala快速入门到精通 下载地址链接:https://pan.baidu.com/s/1bqGIKyF 密码:ojwd

  2. scala快速入门之文档注释

    scala快速入门之文档注释 1.在项目栏的目录树中找到该源码,右击点击Show in Explorer, 即可找到该源码的本地路径,在路径中输入cmd 2.执行scaladoc -d  生成文档注释 ...

  3. Scala快速入门 - 基础语法篇

    本篇文章首发于头条号Scala快速入门 - 基础语法篇,欢迎关注我的头条号和微信公众号"大数据技术和人工智能"(微信搜索bigdata_ai_tech)获取更多干货,也欢迎关注我的 ...

  4. Scala快速入门(四)——继承、接口

    Scala快速入门(四)--继承.接口 一.继承 1.继承的概念:省略 2.模板: class Person(n:String,a:Int) { var name:String=n var age:I ...

  5. Scala - 快速学习05 - 数据结构

    1- 数组(Array) 数组一般包括定长数组和变长数组. 可以不指明数组类型,Scala会自动根据提供的初始化数据来推断出数组的类型. 在Scala中,对数组元素的应用,是使用圆括号,而不是方括号. ...

  6. Spark(七) -- Scala快速入门

    Scala作为Spark的开发语言,想要成为Spark高手,精通Scala是必须要走的一条路 然后一门语言并不是你想精通就能够精通的,更何况是Scala这种面向对象又面向函数的编程语言,个人觉得其学习 ...

  7. Scala 快速入门

     Scalable 编程语言 纯正的的面向对象语言 函数式编程语言 无缝的java互操作 scala之父 Martin Odersky 1. 函数式编程 函数式编程(functional progr ...

  8. Spark记录-scala快速入门

    1.hello world程序 object HelloWorld { def main(args: Array[String]) { println("Hello,World!" ...

  9. Scala快速入门-基础

    HelloWorld 从HelloWorld开始,使用scala IDE编辑器. 新建scala project 新建scala object 编写HelloWorld run as scala ap ...

随机推荐

  1. Nginx(haproxy)+keepalived+Tomcat双主高可用负载均衡

    周末的时候一个正在学Linux的朋友问我,高可用怎么玩?我和他微信了将近三个小时,把Nginx和haproxy双主高可用教给他了,今天突然想把这个给写进博客里,供给那些正在学习Linux系统的朋友们, ...

  2. 『Python基础-7』for循环 & while循环

    『Python基础-7』for循环 & while循环 目录: 循环语句 for循环 while循环 循环的控制语句: break,continue,pass for...else 和 whi ...

  3. apache上.htaccess转向nginx上配置.htaccess伪静态规则

    nginx上配置.htaccess伪静态规则 在apache上.htaccess转向,只要apache编译的时候指明支持rewrite模块即可. 但是换到nginx上方法会有不同,有人说把.htacc ...

  4. 二维离散余弦变换(2D-DCT)

    图像处理中常用的正交变换除了傅里叶变换以外,还有一些其它常用的正交变换,其中离散余弦变换DCT就是一种,这是JPEG图像压缩算法里的核心算法,这里我们也主要讲解JPEG压缩算法里所使用8*8矩阵的二维 ...

  5. 16-oauth2-oidc-Client实现

    1-新建.net core2.1 mvc网站 2-在Startup.config文件增加相关代码, 下面代码已经配置好oidc客户端了,并设置本mvc启动ip为5009 public void Con ...

  6. JAVA日志框架概述

            日志用来记录应用的运行状态以及一些关键业务信息,其重要性不言而喻,通常我们借助于现有的日志框架完成日志输出.目前开源的日志框架很多,常见的有log4j.logback等,有时候我们还会 ...

  7. 「日常训练」Brackets in Implications(Codeforces Round 306 Div.2 E)

    题意与分析 稍微复杂一些的思维题.反正这场全是思维题,就一道暴力水题(B).题解直接去看官方的,很详尽. 代码 #include <bits/stdc++.h> #define MP ma ...

  8. 微信小程序—day03

    昨日问题 接着上一篇,昨天遇到的scroll-view组件不能滚动的问题. 今天经过调试,发现是由于:图片的实际宽高,大于给image设定的宽高导致的. 解决办法: 减小图片的实际宽高,使之小于ima ...

  9. HTTP请求中get和post的区别是什么

    GET和POST是Http请求中最常用的两种请求方法 首先介绍GET与POST的差异: (1)GET请求资源数据,POST向服务器传递需要处理的数据 (2)GET传递数据大小不超过2kb,POST没有 ...

  10. Python 的非正式介绍

    在下面的例子中,通过提示符 (>>> 与 ...) 的出现与否来区分输入和输出:如果你想复现这些例子,当提示符出现后,你必须在提示符后键入例子中的每一个词:不以提示符开头的那些行是解 ...