文档章节

scala学习第七天Map

我是菜鸟我骄傲
 我是菜鸟我骄傲
发布于 2017/02/27 08:13
字数 434
阅读 9
收藏 0
package com.learn.scala



/**

* scala学习第七天

* Created by zhuqing on 2017/2/26.

*/

object Day7Map {

def main(args: Array[String]): Unit = {

/**

* Map的初始化,有两种方式

* 1.key -> value :这种看起来更直观一些

* 2.(key,value)

*/

//Map的初始化,

val map = Map("Robbie"->100,"Tom"->90,"Lizzy"->89);

//Map的另一种初始化

val map2 = Map(("Robbie",100),("Tom",90),("Lizzy",89))

// map("Robbie") = 99 error 直接取的Map 是scala.collection.immutable包的, 是不可变的

//map += ("Jhon"->78) error,同上



/**

* scala.collection.mutable包下的Map 是可变的,该包下其他的Map,集合参考:

* http://www.scala-lang.org/api/current/scala/collection/mutable/index.html

*/



var mapMutable = scala.collection.mutable.Map("Robbie"->100,"Tom"->90,"Lizzy"->89);

//Map值修改增加 比Java的方便多了

mapMutable("Tom") = 88

mapMutable("Jhon")=89

//Map也有mkString方法 , mkString是特质GenTraversableOnce中的方法,

// Api http://www.scala-lang.org/api/current/scala/collection/GenTraversableOnce.html

println(mapMutable.mkString("||"))//Robbie -> 100;Lizzy -> 89;Tom -> 88;Jhon -> 89,更新了Tom,新增了Jhon



//+ 方法拼接或修改

mapMutable = mapMutable + ("Buke"->67,"Tom"->80)

println(mapMutable.mkString("||"))

//打印Robbie -> 100||Lizzy -> 89||Tom -> 80||Jhon -> 89||Buke -> 67

//新增了Buke,修改了Tom

// += 另一种增加或修改的方式,+ 和+= 与数字中的+ 和+= 功能类似

mapMutable += ("Tom"->98,"Lily"->90)

println(mapMutable.mkString("||"))

//打印Robbie -> 100||Lizzy -> 89||Tom -> 98||Lily -> 90||Jhon -> 89||Buke -> 67

//新增了Lily,修改了Tom

/**

* -,-= 方法从Map中去除。

*/

mapMutable -= ("Lily")

mapMutable = mapMutable - ("Buke")

println(mapMutable.mkString("||"))

//打印Robbie -> 100||Lizzy -> 89||Tom -> 98||Jhon -> 89

//去除了Lily,和Buke

//更多方法:http://www.scala-lang.org/api/current/scala/collection/mutable/Map.html



/**

* Map下的取值可以直接去,也可以像Java一样使用get方法,但是Scala中Map的get方法返回的类型是Option,而不直接是值。

* 关于Option的Api:http://www.scala-lang.org/api/current/scala/Option.html

* 或Scala提供的方法 getOrElse(key,defalutValue):key不存在使用默认值

*/

println(mapMutable("Robbie"))

println(mapMutable.get("Tom").get)

//没有Key为Emmily的值,返回默认值0

println(mapMutable.getOrElse("Emmily",0))



}

}

 

© 著作权归作者所有

共有 人打赏支持
我是菜鸟我骄傲
粉丝 12
博文 219
码字总数 138106
作品 0
西安
架构师
Scala 学习笔记 模式匹配

1. 模式匹配简介 模式匹配是 Scala 的重要特性之一,前面两篇笔记Scala学习笔记(六) Scala的偏函数和偏应用函数、Scala学习笔记(七) Sealed Class 和 Enumeration都是为了这一篇而铺垫准备的...

Tony沈哲
2017/05/16
0
0
Scala基础入门-3

学习Scala——映射和元组 映射和和元组,也就是Maps和Tuples。Map这东西应该都挺明白的,就是键值对的集合。而元组,tuple,这东西并不是每个语言都有(Python中是有的,不过当时学的时候没有...

wei-spring
2015/11/11
0
0
分享一个用Scala Play + Slick 开始写的一个学习的开源web app

好, 最近在學Play,用Play在這些天寫了一個初始的app,用的是Play! framework 2.x + Play slick 1.x,前端用的是,原始的bootstrap。已经开源,https://github.com/hellomaya/scala-connec...

自由之信
2016/01/24
904
2
【Scala-ML】如何利用Scala构建并行机器学习系统

引言 在学习Scala的过程中,我发现其在构建大规模分布式计算系统上有与生俱来的特质。其丰富的类型系统可以帮助编程设计提供很好的信息隐藏和抽象,其monoids和monads概念利用Scala高阶函数实...

JasonDing
2016/03/19
0
0
spark2.x由浅入深深到底系列六之RDD java api调用scala api的原理

学习spark任何的技术之前,请正确理解spark,可以参考:正确理解spark RDD java api其实底层是调用了scala的api来实现的,所以我们有必要对java api是怎么样去调用scala api,我们先自己简单...

tangweiqun
2017/09/17
0
0

没有更多内容

加载失败,请刷新页面

加载更多

学习大数据为什么要先学Java?

计算机编程语言有很多,目前用的多一点的就是Java,C++,Python等等。目前大多数学习大数据的人都是选择学习Java,那Java到底好在哪呢?为什么学大数据之前要先学Java呢?我们今天就来分析一...

董黎明
17分钟前
0
0
php删除服务器所有session

php删除服务器所有session踢掉所有在线用户linux 注意:如果要删除服务器上所有session,重启php服务是解决不了问题的,php的session是持久化的。 有效解决办法: 删除 /tmp 下的所有文件(默...

妖尾巴
23分钟前
0
0
Ubuntu18.04 安装最新版WPS

1.手动卸载libreoffice:sudo apt-get remove --purge libreoffice* 2.官网下载WPS和字体: WPS:http://wps-community.org/download.html 字体:http://wps-community.org/download.html?vl......

AI_SKI
51分钟前
4
0
数据结构(算法)-图(深度优先搜索 DFS)

#include <iostream>using namespace std;#define MaxVex 30typedef char VertexType;typedef struct vexNode adjList[MaxVex];struct edgeNode{int adjvex;//邻接点......

ashuo
56分钟前
1
0
1024 搞事倒计时!距程序员节还有 2 天!

详情请关注微信公众号:七牛云

七牛云
57分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部