Scala同时支持可变集合和不可变集合,包含两个包:

  可变集合:scala.collection.mutable

  不可变集合:scala.collection.immutable

Scala默认采用不可变集合,对于几乎所有的集合类,Scala都同时提供了可变(mutable)和不可变(immutable)的版本

Scala的集合有三大类:序列Seq、集Set、映射Map,所有的集合都扩展自Iterable特质

1、元组:可以存放各种不同类型的数据

  val tuple1 = (1,2,"hello",true)

  访问第一个元素:tuple1._1

  元组中最多有22个元素

2、数组

  创建定长数组

    val arr1 = new Array[Int](10)

    val arr2 = Array(1,2,3)

  创建可变数组

    val arr3 = new ArrayBuffer[Int]()

    val arr4 = ArrayBuffer[Int]()

    添加元素:arr3.append(1)

  定长数组和可变数组互相转换

    定长数组转可变数组:arr1.toBuffer  返回结果才是一个可变数组,arr1本身没有变化

    可变数组转定长数组:arr3.toArray  返回结果才是一个定长数组,arr3本身没有变化

3、列表

  创建定长列表

    val list1 = List(1,2,3) //创建时直接分配元素,默认是不可变的,可以存放任何数据

    val nil = Nil //创建一个空列表

    list1(1) //通过索引访问元素,在这访问第二个元素

  列表追加元素

    list1 :+ 4 //在列表后面添加元素,并生成新的列表

    5 :+ list1 //在列表前面添加元素,并生成新的列表

    符号 :: 表示向集合中添加元素,集合对象放在最右边

    符号 ::: 表示将集合中的每一个元素加入到另一个集合中

  创建可变列表

    val buffer1 = new ListBuffer[Int]

    val buffer2 = ListBuffer(1,2,3)

  可变列表添加元素

    buffer1.append(1)

    buffer1 += 2

    buffer1 ++= buffer2  // 符号 ++ 用于连接两个集合,::: 只能用于List类型的集合

4、映射Map

  Scala中不可变Map是有序的,可变Map是无序的,默认情况下是不可变map

  创建可变Map

    val map1 = new scala.collection.mutable.HashMap[String,Int]

    val map2 = scala.collection.mutable.Map("zhangsan" -> 10 , "lisi" -> 20)

  获取key对应的value

    map2("lisi") //如果key不存在,会抛出异常

    map2.contains("wangwu") //判断key是否存在

    map2.get(key).get //get(key)返回的是一个Option对象,Some类型或者是None

    map2.getOrElse() //如果key存在,则返回对应的值;如果key不存在,则返回指定的默认值

  可变map添加元素

    map2 += ("wangwu" -> 30)

    map2 + ("zhaoliu" -> 40 , "tianqi" -> 40)

  可变map删除元素

    map2 -= ("zhangsan" , "lisi") //可以写多个key,没有对应的key也不会报错

    

  

Scala集合总结的更多相关文章

  1. Scala集合操作

    大数据技术是数据的集合以及对数据集合的操作技术的统称,具体来说: 1.数据集合:会涉及数据的搜集.存储等,搜集会有很多技术,存储技术现在比较经典方案是使用Hadoop,不过也很多方案采用Kafka.  ...

  2. Spark:scala集合转化为DS/DF

    scala集合转化为DS/DF case class TestPerson(name: String, age: Long, salary: Double) val tom = TestPerson( ...

  3. Scala集合常用方法解析

    Java 集合 : 数据的容器,可以在内部容纳数据  List : 有序,可重复的  Set : 无序,不可重复  Map : 无序,存储K-V键值对,key不可重复 scala 集合 : 可变集合( ...

  4. Scala集合笔记

    Scala的集合框架类比Java提供了更多的一些方便的api,使得使用scala编程时代码变得非常精简,尤其是在Spark中,很多功能都是由scala的这些api构成的,所以,了解这些方法的使用,将更 ...

  5. Scala集合(一)

    Scala集合的主要特质 Iterator,用来访问集合中所有元素 val coll = ... // 某种Iterable val iter = col.iterator while(iter.ha ...

  6. Scala集合类型详解

    Scala集合 Scala提供了一套很好的集合实现,提供了一些集合类型的抽象. Scala 集合分为可变的和不可变的集合. 可变集合可以在适当的地方被更新或扩展.这意味着你可以修改,添加,移除一个集合 ...

  7. 再谈Scala集合

    集合!集合!一个现代语言平台上的程序员每天代码里用的最多的大概就是该语言上的集合类了,Scala的集合丰富而强大,至今无出其右者,所以这次再回过头再梳理一下. 本文原文出处:  还是先上张图吧,这是我 ...

  8. Spark记录-Scala集合

    Scala列表 Scala列表与数组非常相似,列表的所有元素都具有相同的类型,但有两个重要的区别. 首先,列表是不可变的,列表的元素不能通过赋值来更改. 其次,列表表示一个链表,而数组是平的. 具有类 ...

  9. scala集合与java集合的转换应用

    今天在业务开发中遇到需要Scala集合转为Java集合的场景: 因为业务全部是由Scala开发,但是也避免不了调用Java方法的场景,所以将此记录下来加深记忆: import scala.collec ...

  10. Scala集合学习总结

    遍历集合可以使用迭代器iterator的那套迭代方式.Seq是一个有先后次序的序列,比如数组或列表.IndexedSeq可以通过下标进行任意元素的访问.例如ArrrayBuffer. Set是一组没有 ...

随机推荐

  1. 深度学习-LSTM

    目录 前言 神经网络的历史和背景 循环神经网络的出现及其作用 LSTM在处理序列数据中的应用 LSTM的基本原理 LSTM的结构和原理 遗忘门.输入门.输出门的作用 LSTM的训练方法 代码 LSTM ...

  2. AIR32F103(九) CAN总线的通信和ID过滤机制及实例

    目录 AIR32F103(一) 合宙AIR32F103CBT6开发板上手报告 AIR32F103(二) Linux环境和LibOpenCM3项目模板 AIR32F103(三) Linux环境基于标准外 ...

  3. OpenLayers点聚合

    1. 引言 当页面加载的数据量过大时,拖拽.缩放时往往会产生卡顿 然而,页面实现的内容是有限的,人眼可见范围也是有限的,过于微小的部分是可以不予显示的 聚合是解决这种问题的一个办法,当数据比较多,单个 ...

  4. XView 架构升级之路

    作者:京东零售 胡本奎 一 背景 1 是什么 XView是一个透明的塑料袋(容器),基于通用的webview框架改造而来,通常用于大促弹窗等营销场景,展现形式如下图: 2 痛点 在实际的开发使用中XV ...

  5. LeetCode-442 数组中重复的数据

    来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/find-all-duplicates-in-an-array 题目描述 给你一个长度为 n 的整 ...

  6. Linux修改开机图形/etc/motd

    修改 /etc/motd vim /etc/motd 植入图形 .--, .--, ( ( \.---./ ) ) '.__/o o\__.' {= ^ =} > - < / \ // \ ...

  7. Windows.h 文件学习

    SDk :软件开发工具包 Api  :Windows操作系统提供给应用程序编程的接口,windows.h 窗口:窗口是屏幕上的一块矩形区域,是Windows应用程序与用户进行交互的接口,分为客户区与非 ...

  8. winform 更新下载压缩文件解压并覆盖

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  9. Android集成并开启手写笔识别

    1.首先,需要下载Pdf xchange View SDK,然后将其集成到Android项目中: 2.在Android项目中,添加以下依赖: implementation 'com.github.PD ...

  10. go简单写个ini配置文件读取工具

    直接上代码: 1 package main 2 3 import ( 4 "fmt" 5 "io/ioutil" 6 "reflect" 7 ...