*Scala有十分易用的语法来创建、查询和便利映射

*你需要从可变的和不可变的映射中做出选择

*默认情况下,你得到的是一个哈希映射,不过你也可以指明要树形映射

*你可以很容易地在Scala映射和Java映射之间来回切换

*元组可以用来聚集值

构造映射

 

 val scores=Map("Alice"->10,"Bob"->3,"zhangzhilong"->9,"huyanan"->11)

  

  上述代码构造出一个不可变的Map[String,Int]其值不可改变。如果你想要一个可变映射,则用

  val scores=scala.collection.mutable.Map("Alice"->10,"Bob"->3,"zhangzhilong"->9,"huyanan"->11)

如果想从一个空的映射开始,你需要选定一个映射实现并给出类型参数

val scores=new scala.collection.mutable.HashMap[String,Int]

在Scala中,映射是对偶的集合。对偶简单的说就是两个值构成的组,这两个值并不一定是同一个类型的,比如("Alice",10)

->操作符用来创建对偶

"Alice"->10

产出值为:

("Alice",10)

你也可以完全用另一种方式定义映射

val scores=Map(("Alice",10),("Bob",3),("Cindy",8))

只不过->操作符看上去比圆括号易读那么一点,也更符合大家对于映射的直观感受

映射这种数据结构是一种将键映射到值的函数。区别在于通常的函数计算值,而映射只是做查询

获取映射中的值

使用()表示法查找某个键对应的值

val bobsScore=score("Bob")//类似于Java中的scores.get("Bob")

如果映射并不包含请求中使用的键,则会抛出异常

要检查映射中是否包含某个指定的键,啧可以用contains方法

val bobsScore=if(scores.contains("Bob")) SCORES("Bob") else 0

由于这样的组合调用十分普遍,以下是一个快捷写法:

val bob=scores.getOrElse("Bob",0)//如果映射包含键"Bob",返回对应的值,否则返回0

最后。映射.get(键)这样的刁颖返回一个Option对象,要么是Some(键对应的值),要么是None

更新映射中的值

跟新某个映射的值或者添加一个新的映射关系:

  在=左侧使用()

    scores("Bob)=10//更新或增加键“Bob”对应的值(假定scores是可变的)

  或者使用 +=操作来添加多个关系:

    scores +=("Bob"->10)

  要溢出某个键和对应的值,使用-=操作符

    scores-="Alice"

  你不能更新一个不可变的映射,但你可以做一些同样有用的操作——获取一个包含所需要的更新的新映射:

    val newScores = scores + ("Bob"->10)//更新过的新映射(如果是两个scores这样的映射的话用++相连)

newSores映射包含了于scores相同的映射关系,此外“Bob“被更新,”Fred“被添加了进来

同理要从不可变易守难攻he中移除某个键,你可以用-操作符来获取一个新的去掉该键

scores=scores-“Alice”

迭代映射

for((k,v)<-映射)处理k和v

只访问k或者v

for (v<- scores.values)println(v)

k,v交换位置

for((k,v)<-映射)yeild (v,k)

已排序映射

 顺序访问所有键(属性映射)

val scores=scala.collection.immutable.SortedMap(“Alice”->10,"huyanan"->8)

元组

映射是键/值对偶的集合。对偶是元组的最简单形态——元组是不同类型的值的聚合

例如(1,3.14,"zhangzhilong")

是一个元组,类型为Tuple3[Int,Double,String]

类的定义也可以写为

  (Int,Double,java.lang.String)

如果你有一个元组,比如:

val t=(1,3.14,"fred")

和数组或字符串中的位置不同,元组的各族从1开始而不是0

通常,使用模式匹配来获取元组的组元,例如

val (first,second,third)=t//将first设为1 second设为3.14 third设为“Fred”

如果不是所有的部件都需要,那么可以再不需要的部件位置上使用_

val (first,second,_)=t

元组可用于函数需要返回不止一个值的情况。如StringOps的partition方法返回的是一对字符串,分别包含了满足某个条件和不满足该条件的字符

"NewYork".partition(_.isUpper)//输出对偶("NY","ew ork")

拉链操作

 多个值绑在一起,以便能够一起被处理  通常用zio方法完成

val arr1=Array("<","=",">")

val arr2=Array(2,10,2)

val pairs=arr1.zip(arr2)

输出对偶的数组:

Array((<,2), (=,10), (>,2))

然后这些对偶就可以一起被处理

for((s,n)<-pairs) Console.print(s*n)//会打印<<==========>>

Scala映射与元组篇的更多相关文章

  1. 【scala】 scala 映射和元组操作(四)

    1.映射  Map 定义 ,取值,遍历,排序 2. 元组 定义,取值,拉链操作 import scala.collection.mutable /** * 映射和元组 * * @author xwol ...

  2. scala映射和元组

    scala映射,是一对键值对,相当于java中的Map 对偶:由两个值构成的组,形式 : 值1->值2,值1和值2类型不一定要相同,可以理解为对偶就是一个key/value 映射就是对偶的集合 ...

  3. Scala学习(四)---映射和元组

    映射和元组 摘要: 一个经典的程序员名言是:"如果只能有一种数据结构,那就用哈希表吧".哈希表或者更笼统地说映射,是最灵活多变的数据结构之一.映射是键/值对偶的集合.Scala有一个通用的叫法:元组, ...

  4. 学好Spark/Kafka必须要掌握的Scala技术点(一)变量、表达式、循环、Option、方法和函数,数组、映射、元组、集合

    前言 Scala是以JVM为运行环境的面向对象的函数式编程语言,它可以直接访问Java类库并且与Java框架进行交互操作.正如之前所介绍,Spark是用Scala语言编写的,Kafka server端 ...

  5. Scala从入门到精通之四-映射和元组

    在Scala中映射之键值对的集合,元组是n个对象的聚集,但是对象的类型不一定相同 本节内容要点 Scala中映射的创建,遍历和查询 如何从可变和不可变映射中做出选择 Scala映射和Java映射见的互 ...

  6. 快学Scala习题解答—第四章 映射和元组

    4 映射和元组  4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格.然后构建还有一个映射.採用同一组键,可是价格上打9折 映射的简单操作  ,"gun"->18 ...

  7. Scala的映射和元组操作

    映射和元组操作 构造Map // 构造一个不可变的MAP映射,类似与key -> value这样的组合叫做对偶 val score = Map("Jack" -> 12 ...

  8. scala学习笔记(4)映射和元组

    1.构造映射 //构造这样的一个映射 val sources=Map(,,) //构造了一个不可变的Map[String,Int],值不能改变, //可变映射 val scores = new sca ...

  9. Scala从入门到放弃(三)Scala的数组、映射、元组和集合

    1.数组 1.1定长数组和变长数组 object ArrayDemo { def main(args: Array[String]): Unit = { //初始化一个长度为8的定长数组,其数组元素均 ...

随机推荐

  1. jdk5升级至jdk8框架版本选型

    spring-framework-4.3.18.RELEASE 4.3.x+:JDK8  Spring JDK Version Range Spring Framework 5.1.x: JDK 8- ...

  2. Restful levels and Hateoas

    RESTful: Rest是一种软件架构风格.设计风格,而不是标准,只是提供了一组设计原则和约束条件.它主要用于客户端和服务器交互类的软件.基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等 ...

  3. MMIO和PIO

    1.概念 内存映射I/O(MMIO)[统一编址]和端口映射I/O(PMIO)[独立/单独编址]是两种互为补充的I/O方法,用于设备驱动程序和设备通信,即在CPU和外部设备之间. (1)在MMIO中,内 ...

  4. java 接口详解

    定义接口 接口继承和实现继承的规则不同,一个类只有一个直接父类,但可以实现多个接口.Java 接口本身没有任何实现,只描述 public 行为,因此 Java 接口比 Java 抽象类更抽象化.Jav ...

  5. 宝塔安装swoole

    新建文件夹 mkdir swoole 切入到文件夹中,进行下载安装包 wget http://pecl.php.net/get/swoole-4.3.2.tgz 解压 tar -zxvf swoole ...

  6. get 和 post 请求的区别,一个不错的链接

    https://www.cnblogs.com/logsharing/p/8448446.html

  7. Spark大型电商项目实战-及其改良(2) RDD优化效果不稳定的真正原因

    首先看没有map join的第2任务: 时间线如下 接着是对应id的算子计算时间表 Stage Id Description Submitted Duration Tasks: Succeeded/T ...

  8. 自制操作系统Antz(15)——实现启动界面

    AntzScript

  9. day14带参装饰器,迭代器,可迭代对象 , 迭代器对象 ,for迭代器 , 枚举对象

    复习 ''' 函数的嵌套定义:在函数内部定义另一个函数 闭包:被嵌套的函数 -- 1.外层通过形参给内层函数传参 -- 2.验证执行 开放封闭原则: 功能可以拓展,但源代码与调用方式都不可以改变 装饰 ...

  10. java.lang.IllegalStateException: getWriter() has already been called for this response

    出现此异常的三种可能: 1.通过response.reset(); 刷新可能存在一些未关闭的getWriter().  来源:http://blog.csdn.net/wonder4/article/ ...