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

  在Scala中映射之键值对的集合,元组是n个对象的聚集,但是对象的类型不一定相同

本节内容要点

  1.   Scala中映射的创建,遍历和查询
  2.   如何从可变和不可变映射中做出选择
  3.   Scala映射和Java映射见的互操作
  4.   Scala中元组的使用

一.构造映射

   我们可以这样来构造一个映射:

val scores = Map("ysl"->100,"wdd"->90)

   上述代码构造一个不可变的Map[String,Int],其值不可以被改变。如果需要创建一个可变的映射,可以用:

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

在Scala中,映射是对偶的集合。对偶简单的说就是两个值构成的组,这两个值的类型不要求相同,比如("ysl",100)

->操作符用于创建对偶

"ysl" -> 100

上述代码的职位("ysl",100)

因此,完全可以用下面的方式来创建映射

val scores = Map(("ysl",100),("wdd",90))

二.获取映射的值

  在Scala中映射和函数之间的相似性十分的明显,因为你可以使用()表示法来查询某个键值对的值

val yslScore = scores("ysl")

如果映射中不包含查询的值,将会抛出异常。

要检查映射中是否包含某个键值可以使用contains方法:

val yslScore = if(scores.contains("ysl")) scores("ysl") else 0

有这种用法十分的普遍,Scala提供了一个简便的方法来简化上述操作 

val yslScore = scores.getOrElse("ysl",0)

注意:映射.get(键)这样的调用的返回值是一个Option对象,要么是Some(键值对的值),要么是None,我们将在后面详细介绍Opion类

三.修改映射中的值

  在可变的映射中,你可以修改映射中的值,或则向映射中添加新的映射关系,做法是在=的左测使用(),例如:

scores("ysl") = 89//更新ysl做对应的值,scores必须是可变的,否则会报错
scores("tom") = 89//增加新的键值对

当然,也可以使用+=操作来添加多个关系

scores += ("jim"->78,"kit"->56)

要移除某个键值对的值使用-=操作

 scores -= "ysl"

你不能更新一个不可变的映射,但是可以基于某个映射生成一个新的映射

val newScores = scores + ("jim"->89,"ketty"->100)

四。映射的便利

  你可以使用如下超级简单的方式便利映射

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

  之所以能这样便利映射,主要是因为Scala的for循环中使用可模式匹配,这样以来不需要冗余的方法调用,你就可以得到每一个对偶的键值

  如果你只需要访问键或则值,像Java一样可以使用keySet和values方法。values方法返回一个Iterable,你可以使用for便利Iterable

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

要转换一个映射,比如交换见和值的位置,可以使用

for((k,v) <- scores) yield (v,k)

 五.排序的映射

  在操作映射的时候,你需要选择一个实现-一个hash表或则一个平衡树。默认Scala使用的是hash表。如果需要顺序访问所有的键,你需要一个树型映射

要得到一个不可变的树型映射的话可以使用:

val scores = scala.collection.immutable.SortedMap("ysl"->10,"wdd"->8,"tom"->9)

但是Scala2.12.3中没有可变的树型映射,要实现可变的树型映射,需要使用Java的TreeMap

如果要按照插入的顺序访问插入的键,可以使用LinkedHashMap

六.映射Scala与Java互操作

如果你想要Java的映射转换为Scala的映射,以便方便的使用Scala的API。这对于需要操作Scala并没提供的可变的树型映射的情况是十分的有用的。

你只需要引入如下的语句便可实现:

import scala.collection.JavaConversions.mapAsScalaMap

然后制定Scala的映射类型来触发转换

val scores:scala.collection.mutable.Map[String,Int] = new java.util.TreeMap[String,Int]

除此之外,你还可以得到从.util.Proterties到Map[String,String]的转换

import scala.collection.JavaConversions.propertiesAsScalaMap
val props:scala.collection.Map[String,String] = System.getProperties()

反过来把Scala的映射转换为Java的映射,提供相反的隐士转换即可:

import scala.collection.JavaConversions.mapAsJavaMap
import java.awt.font.TextAttribute._
val attrs = Map(FAMILY -> "Serif",SIZE -> 12)
val font = new java.awt.Font(attrs)

七.元组

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

  元组是将单个值包含在()中构成的,例如

  (1,3.14,"tom")

  类型是:Tuple3(Int,Double,String),也可以写成(Int,Double,String)

  你可以使用方法_1,_2,_3来访问元组,比如:

val second = tt._2

和数组和字符串中的下边不同,元组的下边是从1开始的。

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

val (first,second,third) = tt

如果不是每一个组员都需要,可以在不需要的位置使用_,例如:

val (first,second,_) = tt

元组可以用于函数返回值不是一个值的情况。关于函数将在后面详细介绍

八.拉链操作

  使用元组的原因之一是把多个值绑定在一起,以便他们能够被统一处理,这通常可以用zip方法来完成。例如:

val symbols = Array("<","-",">")
val count = Array(2,10,2)
val pairs = symbols.zip(count)

输出结果为:pairs: Array[(String, Int)] = Array((<,2), (-,10), (>,2))

然后可以对输出结果作统一的处理:

for((s,n) <- pairs) Console.print( s * n)

输出结果:<<---------->>

toMap方法可以对偶集合转化为映射。如:

symbols.zip(count).toMap
时间: 2024-08-29 13:30:53

Scala从入门到精通之四-映射和元组的相关文章

scala学习3 数组相关操作映射和元组

一.定长数组 如果需要一个长度不变的数组,可以使用Scala中的Array. val nums = new Array[int](10) val s = Array("Hello","world") 二.变长数组:数组缓冲 1. val b = ArrayBuffer[int]() 2.追加元素 b +=(1,2,3,4,5) 3.追加任何集合 b ++= Array(8,13,21) 4.移除最后5个元素 b.trimEnd(5) 5.插入元素 b.insert(

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

4 映射和元组 4.1 设置一个映射,其中包含你想要的一些装备,以及它们的价格.然后构建另一个映射,采用同一组键,但是价格上打9折 映射的简单操作 Shell代码   scala> val map = Map("book"->10,"gun"->18,"ipad"->1000) map: scala.collection.immutable.Map[java.lang.String,Int] = Map(book ->

oracle数据库从入门到精通之四

序列是oracle中较为重要的概念事务对于ddl是不起作用的查询,更新,数据表,约束这些个概念要掌握. 在许多数据库之中都会存在一种数据类型--自动增长列,它能够创建流水号12c之前并没有提供这样一个自动增长的列,如果想要使用自动增长的列可以用序列来完成.序列属于数据库对象的创建过程,属于ddl的分类范畴,对于序列而言,会在数据字典中保存select * from user_sequences;时间戳+序列 如果要想使用序列则可以使用如下两个伪列nextval:取得序列下一个内容值.每一次调用序

Scala2.12 从入门到精通实战高端视频课程(含网盘下载地址)

Scala快速入门到精通 下载地址链接:https://pan.baidu.com/s/1bqGIKyF  密码:ojwd 下载后使用视频中自带的专用播放器打开视频就能看见机器码,然后把机器码发过来,我们会根据机器码为您制作播放码 原文地址:https://www.cnblogs.com/daoke360/p/11373283.html

(升级版)Spark从入门到精通(Scala编程、案例实战、高级特性、Spark内核源码剖析、Hadoop高端)

本课程主要讲解目前大数据领域最热门.最火爆.最有前景的技术——Spark.在本课程中,会从浅入深,基于大量案例实战,深度剖析和讲解Spark,并且会包含完全从企业真实复杂业务需求中抽取出的案例实战.课程会涵盖Scala编程详解.Spark核心编程.Spark SQL和Spark Streaming.Spark内核以及源码剖析.性能调优.企业级案例实战等部分.完全从零起步,让学员可以一站式精通Spark企业级大数据开发,提升自己的职场竞争力,实现更好的升职或者跳槽,或者从j2ee等传统软件开发工程

Scala入门到精通——第三十节 Scala脚本编程与结束语

本节主要内容 REPL命令行高级使用 使用Scala进行Linux脚本编程 结束语 1. REPL命令行高级使用 在使用REPL命令行时,有时候我们需要粘贴的代码比较大,而普通的粘贴可能会些一些问题,比如中文粘贴会出现乱码.多行代码粘贴时会出错,此时需要用到REPL的高级功能.在日常开发过程中,我们粘贴多行代码的时候会遇到下列问题: //本意是要粘贴下面两行代码 class Person(val name:String,val age:Int) val p=new Person("摇摆少年梦&q

Spark2.0从入门到精通:Scala编程、大数据开发、上百个实战案例、内核源码深度剖析视频教程

38套大数据,云计算,架构,数据分析师,Hadoop,Spark,Storm,Kafka,人工智能,机器学习,深度学习,项目实战视频教程 视频课程包含: 38套大数据和人工智能精品高级课包含:大数据,云计算,架构,数据挖掘实战,实时推荐系统实战,电视收视率项目实战,实时流统计项目实战,离线电商分析项目实战,Spark大型项目实战用户分析,智能客户系统项目实战,Linux基础,Hadoop,Spark,Storm,Docker,Mapreduce,Kafka,Flume,OpenStack,Hiv

mybatis从入门到精通(三) 结果映射

mybatis从入门到精通(三) 结果映射 一丶什么是结果映射 结果映射是用于将数据库表字段和实体类中的属性名映射起来, 即究竟是哪个字段名与属性名对应. 映射之后, 即可通过mybatis将从数据库查询的结果转换成对应的实体类对象类型, 除去了人工转换的麻烦. 二丶自动映射 所谓的自动映射, 即是默认java实体类的属性名是驼峰式, 而数据库表字段名是以下划线分隔, 如 属性名userName 与 表字段user_name相对应, 如果是这种简单通用的规则, 即可通过配置mybatis, 使得

MyBatis从入门到精通(十一):MyBatis高级结果映射之一对多映射

最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解MyBatis中如何使用collection标签实现查询结果一对多映射. 1. 使用collection标签 需求:根据用户id查询用户信息的同时获取用户拥有的角色,一个用户可以拥有1个或多个角色. 一般情况下,不建议直接修改数据库表对应的实体类. 所以这里我们延用之前博客中新建的类SysUserExtend,并添加如下代码,如下