scala - Map基础
Map
构造Map
不可变:
val map = Map("sa" -> 1, "s" -> 2)
map("sa") = 3 // error
val emptyMap = new scala.collection.immutable.HashMap[String, Int]
可变:
val map2 = scala.collection.mutable.Map("sa" -> 2)
map2("sa") = 3
val emptyMap = new scala.collection.mutable.HashMap[String, Int]
注:->用来创建元组, "sa" -> 1即("sa", 1)
初始化完全可以 val map = Map(("sa", 1), ("s", 2))
获取Map中的值:
如果map中不包含请求中使用的key值,则抛异常。NoSuchElementException
map("sa") // 类似于java中的map.get("sa")
要检查map中是否包含某个key,使用contains方法。
val sa = if (map2.contains("sa3")) map2("sa3") else 0;
快捷的方式:
val sa2 = map.getOrElse("sa2", 0)
一次得到是否包含key,并获取值:
val sa3 = map.get("sa3"); // Option类型,
println(sa3.isEmpty)
更新Map中的值:
添加或更新:
map("sa") = 3
添加或更新多个:
map += ("aa" -> 4, "bb" -> 5)
移除某个key和对应的值:
map -= "aa"
不可变的map也可以使用+和-操作,但是会生成新的map
var map = Map("aa" -> 1)
map = map + ("bb" -> 2)
map += ("cc" -> 2)
map -= "aa"
迭代map:
for ((k, v) <- map) {
// TODO
}
所有key:
map.keySet
所有值:
map.values
反转:
map2 = for((k, v) <- map) yield (v, k)
已排序Map:
按key排序:
SortedMap
按添加顺序:
LinkedHashMap
Map与Java互操作:
Java Properties转为scala.collection.Map:
import scala.collection.JavaConversions.propertiesAsScalaMap
val prop: scala.collection.Map[String, String] = System.getProperties();
Java Map转为scala.collection.mutable.Map[String, Int]:
import scala.collection.JavaConversions.mapAsScalaMap
val map: scala.collection.mutable.Map[String, Int] = new TreeMap[String, Int]
Scala Map转为Java Map:
import scala.collection.JavaConversions.mapAsJavaMap
import java.awt.font.TextAttribute._
var fs = Map(FAMILY -> "Serif", SIZE -> 12)
var fonts = new Font(fs)
scala - Map基础的更多相关文章
- Scala 语法基础
一 简介 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Java虚拟机上,并兼容现有的Java程序.Scal ...
- Scala语言基础
1. Scala语言的特点 a. 多范式编程语言,面向对象(抽象.封装)和函数式(过程.结果)编程 b. 代码简洁 ==>可读性较差 c. 代码会被变异成Java字节码,运行在JVM上 2. S ...
- Scala零基础教学【1-20】
基于王家林老师的Spark教程——共计111讲的<Scala零基础教学> 计划在9月24日内完成(中秋节假期之内) 目前18号初步学习到25讲,平均每天大约完成15讲,望各位监督. 初步计 ...
- Scala(一) —— 基础
一.输出 println("Hello World") 二.变量与常量 1.变量用var表示,常量使用val表示 2.变量类型声明 var variableName : DateT ...
- Scala编程基础
Scala与Java的关系... 4 安装Scala. 4 Scala解释器的使用... 4 声明变量... 5 数据类型与操作符... 5 函数调用与apply()函数... 5 if表达式... ...
- Scala学习——基础篇
[<快学Scala>笔记] 一.基础 1.变量val 标志符: 声明常量: 如,val answer = 1var 标志符:声明变量: 类型推断:变量的类型由scala根据初始化变量的表达 ...
- Scala map与flatMap
1. map函数 对集合的每一个元素运用某个函数操作,然后将结果作为一个新的列表返回. 实例1:将列表中每个元素值乘以2 scala> val list1=List(1,2,3,4) lis ...
- Spark记录-Scala语法基础
参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...
- scala map操作 简单总结
在函数式编程中有一个核心的概念之一是转换,所以大部份支持函数式编程语言,都支持一种叫map()的动作,这个动作是可以帮你把某个容器的内容,套上一些动作之后,变成另一个新的容器. 现在我们考虑如何用Op ...
随机推荐
- 搭建Mantis 缺陷管理系统(转)
转自 什么是Mantis MantisBT is a free popular web-based bugtracking system (feature list). It is written i ...
- 数字信号处理实验(六)——FIR滤波器的设计
一.四种线性相位FIR滤波器的振幅响应 1.自编函数 [Hr,w,a,L]=-n) [Hr,w,a,L]=-n) [Hr,w,a,L]=-n) [Hr,w,a,L]=-n) 2.一个demo clea ...
- Java中引用类 strong reference .SoftReference 、 WeakReference 和 PhantomReference的区别
当在 Java 2 平台中首次引入 java.lang.ref 包,其中包含 SoftReference . WeakReference 和 PhantomReference 三个引用类,引用类的 ...
- 学习linux内核时常碰到的汇编指令(1)
转载:http://blog.sina.com.cn/s/blog_4be6adec01007xvg.html 80X86 汇编指令符号大全 +.-.*./∶算术运算符. &∶宏处理操作符. ...
- html5 head头标签
桌面端开发中,meta标签通常用来为搜索引擎优化(SEO)及 robots定义页面主题,或者是定义用户浏览器上的cookie:它可以用于鉴别作者,设定页面格式,标注内容提要和关键字:还可以设置页面使其 ...
- Released Mocked Streams for Apache Kafka
Kafka Streams is a deployment-agnostic stream processing library written in Java. Even thoug ...
- 如何将Android Studio项目提交(更新)到github
转载:http://blog.csdn.net/jinrall/article/details/45787477 前言 在写这篇文章之前首先我假设你已经安装了Android Studio 并已经会用A ...
- DrawerLayout的使用
一:首先是DrawerLayout的布局 <android.support.v4.widget.DrawerLayout android:id="@+id/drawer_layout& ...
- UpdatePanel的使用方法
UpdatePanel控件也是Ajax里用得最多的控件之一,UpdatePanel控件是用来局部更新网页上的内容,网页上要局部更新的内容必须放在UpdatePanel控件里,他必须和上一次说的Scri ...
- Linux查看系统配置常用命令
Linux查看系统配置常用命令: 系统 # uname -a # 查看内核/操作系统/CPU信息# head -n 1 /etc/issue # 查看操作系统版本# cat /proc/cpuinfo ...