1.构造映射

//构造这样的一个映射
val sources=Map("Alice"->,"Bob"->,"Cindy"->)  //构造了一个不可变的Map[String,Int],值不能改变,

//可变映射

val scores = new scala.collection.mutable.HashMap[String,Int]
//映射是对偶的集合。简单来说就是两个值构成的组,这两个值不一定适合同一类型的,如("Alice",10)。->操作符用来创建对偶:
"Alice"-> 改代码产出的值是:("Alice",)

2.获取映射中的值:在scala中,函数和映射之间的相似性尤为明显,因为用()表示法来查找某个键对应的值

val bobsScore = if (scores.contains("Bob")) scores("Bob") else 0
val bobSource=sources("Bob")    //类似于Java中的sources.get("Bob"),如果映射中不包含请求中使用的键值,就会抛出异常
  创建可变map
  scala>val map = new scala.collection.mutable.HashMap[Int,Int]
  scala>val map = new scala.collection.mutable.HashMap[Int,Int]()  //调用apply方法 3.更新映射中的值,在可变映射中,可以更新某个映射的值,或者添加一个映射关系,做法是在=号左侧使用():
  scores("bob")=10    //更新"bob"对应的值
  scores("Fred")=7    //更新新的键值对/值对偶到scores(假定是可变的)
  scores+=("Bob"->10,"Fred"->7)  //通过+=操作添加多个关系
  scores-="Alice"          //通过-=移除某个键值对 
  
  val newScores = scores+("Bob"->10,"Fred"->7)  //更新过的新映射,newScores映射包含了与scores相同的映射关系
  并且"Bob"也被更新,"Fred"被添加进来了   var scores=....
  scores =scores+("Bob"->10,"Fred"->7)  //更新var变量   要从不可变映射中移除某个键,需要用-操作符来获取一个新的去掉该映射:
    scores =scores -"Alice"
 4.迭代操作
  
for((k,v)<-映射)    //循环遍历映射中的所有键值对偶
scores.keySet //一个类似Set("Bob","Cindy","Fred","Alice")这样的集合
for(v<-scores.values) println(v) //将打印10 8 7 10 for((k,v)<- 映射) yield(v,k) //翻转一个映射,交换键和值的位置

  5.已排序映射

    得到一个不可变的树形映射

val scores = scala.collection.immutable.SortedMap("Alice"->10,"Fred"->7,"Bob"->3,"Cindy"->8)

  6.与java的互操作

import scala.collection.JavaConversions.mapAsScalaMap //通过制定的scala映射类型来触发转换
val scores:scala.collection.mutable.Map[String,Int0=new java.util.TreeMap[String,Int] import scala.collection.JavaConversions.propertiesAsScalaMap
val props :scala.collection.map[String,String]=System.getProperties

  7.元组

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

    元组的值是通过将的单个的值包含在圆括号中构成的:(1,3.14,"Fred")是一个元组,类型为Tuple3[Int,Double,java.lang.String]
    类型定义也可以写为(Int,Double,java.lang.String)
    eg:val t = (1,3.14,"Fred")  可以通过_1、_2、_3访问其元组
      val second =t._2    //将second设置为3.12  ,这个地方可以把t._2写为t _2(用空格而不是句点),但是不能写成t_2.
    
    使用模式匹配的方式来获取元组的组元,如:val (first,second,thrid)=t  //将first设置为1,second设置为3.14,thrid设置为为"Fried"
    如果不是所有的部件都需要,那么可以在不需要的部件上用_:val (first,sceond,_)=t     元组可以用于函数需要返回不止一个值的情况。维数最高22
    元组tuple scala>val t = (1,"tom",12)
 8.拉链操作
    Zpping咬合操作。使用元组的原因之一就是把多个值绑定在一起,以便他们能够被处理
    下面代码:
  
val symbols = Array("<","-",">")
val counts = Array(,,)
val pairs = symbols.zip(counts) //输出对偶数组:Array(("<",2),("-",10),(">",2)),这些对偶可以被一起处理:
for((s,n)<pairs) Console.print(s*n)  //会打印

//数组


scala学习笔记(4)映射和元组的更多相关文章

  1. Scala学习笔记(五)—— 元组和集合

    1. 映射 映射Java中的Map,即Key/Value的数据形式 映射的创建,有以下两种方法 scala> val map =Map("Lisa" -> 90 , & ...

  2. Scala学习笔记之:tuple、array、Map

    [TOC] 本文<快学Scala>的笔记 tuple学习笔记 tuple的定义 对偶是元组(tuple)的最简单形态--元组是不同类型的值的聚集. 元组的值是通过将单个值包含在圆括号中构成 ...

  3. 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性

    基于.net的分布式系统限流组件   在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...

  4. Scala学习笔记及与Java不同之处总结-从Java开发者角度

    Scala与Java具有很多相似之处,但又有很多不同.这里主要从一个Java开发者的角度,总结在使用Scala的过程中所面临的一些思维转变. 这里仅仅是总结了部分两种语言在开发过程中的不同,以后会陆续 ...

  5. 机器学习(三)--- scala学习笔记

    Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...

  6. Scala学习笔记(一)编程基础

    强烈推荐参考该课程:http://www.runoob.com/scala/scala-tutorial.html 1.   Scala概述 1.1.  什么是Scala Scala是一种多范式的编程 ...

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

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

  8. Scala学习之路 (四)Scala的数组、映射、元组、集合

    一.数组 1.定长数组和变长数组 import scala.collection.mutable.ArrayBuffer object TestScala { def main(args: Array ...

  9. scala 学习笔记(02) 元组Tuple、数组Array、Map、文件读写、网页抓取示例

    package yjmyzz import java.io.PrintWriter import java.util.Date import scala.io.Source object ScalaA ...

随机推荐

  1. 【Leetcode】二叉树的层次遍历

    题目: 给定一个二叉树,返回其节点值自底向上的层次遍历. (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历) 例如: 思路:采用宽度优先搜索. 时间复杂度:O(n).n为节点的数量,遍历所有节 ...

  2. 【转】django rest framework ModelSerializer 、serializers小结

    转自:https://blog.csdn.net/l_vip/article/details/79156113 引言 serializers是什么?官网是这样的”Serializers allow c ...

  3. 使用idea上传项目到码云

    首先,基本流程是这样的:       1.在码云生成SSH公钥       2.在码云创建项目      3.克隆项目到本地      4.在本地创建项目      5.搭建本地仓库,关联远程仓库   ...

  4. [LeetCode]-DataBase-Trips and Users

    The Trips table holds all taxi trips. Each trip has a unique Id, while Client_Id and Driver_Id are b ...

  5. CentOS 7 安装wps2019

    1. download https://www.wps.cn/product/wpslinux 2. rpm 安装缺少lib包,于是yum 安装 .x86_64.rpm 3.安装完成,运行的时候又报错 ...

  6. 网站运营文章LIST

    如何建立网站地图(site map) ● 伤心SEO之太平洋 ● 关键字密度与网站排名 ● 哪些因素决定网站SEO的价格 ● SEO:站在Google背后的搜钱力量 ● 网站被一搜索屏蔽,郁闷! ●  ...

  7. Spring boot 自定义一个starter pom

    用过springboot的自动配置会觉得非常方便,我们完全可以自己写一个starter pom,这样不仅可以有自动配置功能,而且具有更通用的的耦合度低的配置, 新建一个starter的maven项目, ...

  8. rosbag record and play

    话题录制: 录制所有发布出来的话题,此时默认将话题保存在一个以当时时间戳命名的文件夹中:   $ rosbag record -a1 录制指定话题:   $ rosbag record /topic1 ...

  9. 将项目发布到neuxs私服

    需要在 pom.xml中配置 <distributionManagement> <repository> <id>user-release</id> & ...

  10. 搜索练习题——FBI树

    目录: ·题目描述 ·知识拓展 ·题目分析 ·思路分析 ·代码实现 ·总结 ·题目描述: (洛谷P1087 FBI树) 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称 ...