Scala基础入门-3
学习Scala——映射和元组
映射和和元组,也就是Maps和Tuples。Map这东西应该都挺明白的,就是键值对的集合。而元组,tuple,这东西并不是每个语言都有(Python中是有的,不过当时学的时候没有完全分清楚)。
在Scala中,元组是n个对象的一个聚集(Map是n=2个对象的聚集),里面的内容不需要都是相同类型的。
构造Map
在Scala中,Map是对偶(算是键值对的另一个说法吧)的集合。->操作符用来创建对偶,"Alice" -> 10产出 ("Alice", 10)。
然后说说Scala中两个集合包的区别。在scala.collention.mutable包中的集合都是内容可变的,也就是创建了集合之后,集合的内容是可以变化的;而scala.collection.immutable包中,集合的内容是不可变的。由于拥抱函数式的缘故,默认都是使用immutable包。
// 创建一个内容不可变的Map[String, Int]
val scores = Map("Alice" -> 10, "Bob" -> 3, "Cindy" -> 8)
// 创建一个内容可变的Map[String, Int]
val scores = scala.collection.mutable.Map("Alice" -> 10, "Bob" -> 3, "Cindy" -> 8)
// 创建一个空Map[String, Int]
val scores = new scala.collection.mutable.Map[String, Int]
// 替换掉->操作符
val scores = Map(("Alice", 10), ("Bob", 3), ("Cindy", 8))
获取Map中的值
val bobsScore = scores("Bob")
如果Map中没有包含这个键值对,会抛出一个异常。用 contains()方法来检查是否包含指定的键。
由于这个使用方法很多,所以有一个更加快捷的写法:
如果说像Java中,使用 map.get("Bob"),会如何?会返回一个Option对象,要么是Some,要么是None。关于Option,以后介绍…
更改Map
对于可变的Map,更改某个已有的值,或者是添加一个没有的对偶,都是如下:
scores("Fred") = 7
想要添加多个对偶,则使用+=操作:
scores += ("Bob" -> 10, "Fred" -> 7)
移除某个对偶使用-=:
scores -= "Alice"
对不可变的Map来说,操作基本都会是返回一个新的Map:
// 获取一个添加了新对偶的Map
val newScores = scores + ("Bob" -> 10, "Fred" -> 7)
// 获取一个移除了对偶的Map
val newScores = scores - "Alice"
不需要担心这种操作的效率会很低,新旧Map共享大部分的结构。
迭代Map
for ((k, v) <- map)
// 单独拿出键
for (k <- map.keySet)
// 单独拿出值
for (v <- map.values)
已排序映射
在这里我知道了映射的实现方式通常是哈希表或者是一个平衡树。默认用的都是哈希表。如果需要一个排序的映射,就需要使用树形映射了。使用scala.collection.immutable.SortedMap即可。
不过Scala中并没有可变的树形映射,需要的时候使用Java中的TreeMap。
如果要按照插入的顺序访问所有键值,可以使用scala.collection.mutable.LinkedHashMap。
与Java的互操作
与数组中类似,引入函数后就可以触发转换。
// 从Java Map到Scala Map,适用于可变树形映射
import scala.collection.JavaConversions.mapAsScalaMap
// 从Java Properties到Scala Map
import scala.collection.JavaConversions.propertiesAsScalaMap
// 从Scala Map到Java Map
import scala.collection.JavaConversions.mapAsJavaMap
元组(Tuple)
元组是不同类型的值的聚集。
val t = (1, 3.14, "Fred") // 类型为Tuple3[Int, Double, java.lang.String]
// 访问组元
t._1 t._2 等方法,注意是从1开始的
// 不过通常是使用模式匹配来获取组元的
val (first, second, third) = t
// 如果说不是所有的组元都需要,那么在不需要的地方放上_
val (first, second, _) = t
有了这个,可以方便地返回多个值,让我想起了Go。
zip操作
看代码:
val symbols = Array("<", "-", ">")
val counts = Array(2, 10, 2)
val pairs = symbols.zip(counts)
// 得到:Array(("<", 2), ("-", 10), (">", 2))
// 可以使用toMap方法将对偶的集合转换成Map
keys.zip(values).toMap // 可想而知,这个集合需要是有序排列的
fRom:http://nerd-is.in/2013-08/scala-learning-maps-and-tuples/
Scala基础入门-3的更多相关文章
- Scala 基础入门【翻译】
原文地址 本文只是带你进入 Scala 的世界,包括安装.不可变量 val.可变量 var.定义类.集合(包括列表(list).集(set).映射(map))以及集合遍历和集合库(能达到并行/并发效果 ...
- Scala基础入门-1
首先需要Scala开发环境的搭建,网上自己找教程. 声明常量与变量 val foo = 0 // 常量 var bar = 0 // 变量 在Scala中,更加鼓励使用val来进行声明,也就是推荐使用 ...
- Scala基础入门-4
Scala学习——类 简单类和无参方法 class Counter { private var value = 0 // 必须初始化字段 def increment() { value += 1 } ...
- Scala基础入门-2
简单类和无参方法 class Counter { private var value = 0 // 必须初始化字段 def increment() { value += 1 } // 方法默认公有 d ...
- Scala基础入门-代码碎片
import scala.util.control._ import java.util.Date object Test { def main(args: Array[String]) { // v ...
- scala基础入门
1.scala当中申明值和变量 scala当中的变量申明可以使用两种方式,第一种使用val来申明变量.第二种使用var来申明变量. 申明变量语法 val/var 变量名 [:变量类型] = 变量值 其 ...
- Scala快速入门 - 基础语法篇
本篇文章首发于头条号Scala快速入门 - 基础语法篇,欢迎关注我的头条号和微信公众号"大数据技术和人工智能"(微信搜索bigdata_ai_tech)获取更多干货,也欢迎关注我的 ...
- 【原创 Hadoop&Spark 动手实践 5】Spark 基础入门,集群搭建以及Spark Shell
Spark 基础入门,集群搭建以及Spark Shell 主要借助Spark基础的PPT,再加上实际的动手操作来加强概念的理解和实践. Spark 安装部署 理论已经了解的差不多了,接下来是实际动手实 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
随机推荐
- 消除多余的row
tableviewName.tableFooterView = [[UIView alloc]initWithFrame:CGRectZero];
- 使用SignalR和SQLTableDependency跟踪数据库中记录的变动
原文地址:查看 SqlTableDependency是一个组件用来接收数据库的通知,包含在数据表上该记录的值的Inserted.Deleted或者Update操作. 备注:原文提供示例代码下载,但是j ...
- mysql 取得行号后再排序
一.理论准备 Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等. TreeMap:基于红黑树(Red-Black tre ...
- UVA 140 Bandwidth
题意: 给出一个n个节点的图G,和一个节点的排列,定义节点i的带宽为i和相邻节点在排列中的最远距离,而所有带宽的最大值就是图的带宽,求让图的带宽最小的排列. 分析: 列出所有可能的排列,记录当前找到的 ...
- (原)android的JNI中使用C++的类
android的JNI代码中可以调用C++的类,但是不能直接调用,要加上一个类似于接口的java类,这个类内部调用C++的类.实际上和接口类直接调用C++中的函数差不多,只是稍微复杂了一点. 1. 写 ...
- WCF宿主实践入门
本篇属于WCF实践入门,由于博主本人水平有限,没有理论上的介绍,仅仅从其几种不同的宿主方式分别介绍WCF的使用. WCF有多种宿主方式:1.自托管宿主,2.windows service宿主,3.II ...
- externn "C"解析
1.揭密extern "C" extern "C"包含双重含义,从字面上即可得到:首先,被它修饰的目标是 "extern”的:其次,被它修饰的目标是 ...
- PHP中的错误处理
程序只要在运行,就免不了会出现错误!或早或晚,只是时间问题罢了. 错误很常见,比如Notice,Warning等等.此时一般使用set_error_handler来处理: <?php set_e ...
- 关于KeyEvent.Callback
keycode------------>KEYCODE_BACK,KEYCODE_MENU event.getAction------->ACTION_DOWN,ACTION_UP,ACT ...
- COB Epoxy灌膠時氣泡產生的原因與解決方法
COB的黑膠 (Epoxy)有氣泡通常是不被允許的,因為外部氣孔不但會影響到外觀,內部氣孔更有可能會破壞 Wire bonding 的鋁線穩定度.既使在COB製程剛完成的時候沒有通過功能測試,也不代表 ...