一、在使用scala集合时有几个概念必须知道:

1.谓词是什么?

谓词就是一个方法,一个函数或者一个匿名函数,接受一个或多个函数,返回一个Boolean值。

例如:下面方法返回true或者false,所以它是一个谓词。

scala> def isEven(i: Int) = if(i % 2 ==0) true else false
isEven: (i: Int)Boolean

2.匿名函数是什么?

匿名函数也被称作函数自变量,作为变量传入把函数作为参数的方法中,或者赋值给一个变量。

scala> (i: Int) => i % 2 ==0
res22: Int => Boolean = <function1> scala> val list = List.range(1,10)
list: List[Int] = List(1, 2, 3, 4, 5, 6, 7, 8, 9) scala> val ebents = list.filter(_ % 2 == 0)
ebents: List[Int] = List(2, 4, 6, 8)

3.隐私循环是什么?

在上面的例子中,filter方法包含一个循环,会遍历集合里的每个元素然后返回一个新的集合。

scala> for {
| e <- list
| if e % 2 ==0
| }yield e
res23: List[Int] = List(2, 4, 6, 8)

二、集合的层级结构

1.集合类

  • traversable特质遍历了整个集合,scaladoc说他实现了一个就foreach方法而言的所有集合的通用方法,这样就可以反复遍历集合。
  • iterable特质定义了一个迭代器,可以一次循环一个集合元素的方式,但当用迭代器时,集合只允许被循环一次,因为在迭代器的过程中每个元素都被改变了。

2.序列

序列分为两大类,索引序列和线性序列。

  • 索引序列意味着随机存取是最高效的,比如读取数组的元素,如arr(5000)。默认情况下,在scala2.10.x版本中,创建Vector式会认为是一个索引序列。

    scala> val x = IndexedSeq(1,2,3)
    x: IndexedSeq[Int] = Vector(1, 2, 3)
  • 线性序列说明集合可以很方便的被分辨为头尾部分,并且用head、tail和isEmpty方法是很常见的。当创建一个LinearSeq时会创建一个list的列表。

    scala> val seq = scala.collection.immutable.LinearSeq(1,2,3)
    seq: scala.collection.immutable.LinearSeq[Int] = List(1, 2, 3)

3.Map类

  • scala的Map是一个键值对的组合,其中键必须是唯一的。当只需要一个简单的不可变的map时,可以新建一个而不需要import。

    scala> val m = Map(1 -> "a",2 -> "b")
    m: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b)
  • 可变的Map默认不在可变范围,所以必须引用他来使用。
    scala> val m = collection.mutable.Map(1 -> "a",2 -> "b")
    m: scala.collection.mutable.Map[Int,String] = Map(2 -> b, 1 -> a)

4.Set类

scala的set是没有重复元素的集合。

  • 如果只需要不可变的集合,可以这样创建,不需要import引入。

    scala> val set = Set(1,2,3)
    set: scala.collection.immutable.Set[Int] = Set(1, 2, 3)
  • 如果需要可变的集合,必须引用它,或者引用原路径。
    scala> val set = collection.mutable.Set(1,2,3)
    set: scala.collection.mutable.Set[Int] = Set(1, 2, 3)

三、选择一个集合类

  1. scala通用序列集合
  2. 主要的不可变的序列集合类
  3. 主要的可变序列集合类

  4. 在API库中常用的特质
  5. 常用到的map,包括可变和不可变的版本
  6. 常用set,包括可变和不可变的版本
  7. 别的集合类

scala的多种集合的使用(1)之集合层级结构与分类的更多相关文章

  1. scala的多种集合的使用(2)之集合常用方法

    一.常用的集合方法 1.可遍历集合的常用方法 下表列出了Traverable在所有集合常用的方法.接下来的符号: c代表一个集合 f代表一个函数 p代表一个谓词 n代表一个数字 op代表一个简单的操作 ...

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

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

  3. 牛客网Java刷题知识点之Java 集合框架的构成、集合框架中的迭代器Iterator、集合框架中的集合接口Collection(List和Set)、集合框架中的Map集合

    不多说,直接上干货! 集合框架中包含了大量集合接口.这些接口的实现类和操作它们的算法. 集合容器因为内部的数据结构不同,有多种具体容器. 不断的向上抽取,就形成了集合框架. Map是一次添加一对元素. ...

  4. 背水一战 Windows 10 (22) - 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合

    [源码下载] 背水一战 Windows 10 (22) - 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合 作 ...

  5. 【ASP.NET实战教程】ASP.NET实战教程大集合,各种项目实战集合

    [ASP.NET实战教程]ASP.NET实战教程大集合,各种项目实战集合,希望大家可以好好学习教程中,有的比较老了,但是一直很经典!!!!论坛中很多小伙伴说.net没有实战教程学习,所以小编连夜搜集整 ...

  6. 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合

    背水一战 Windows 10 之 绑定 通过 Binding 绑定对象 通过 x:Bind 绑定对象 通过 Binding 绑定集合 通过 x:Bind 绑定集合 示例1.演示如何通过 Bindin ...

  7. 对比两个同类型的泛型集合并返回差异泛型集合 ——两个List<类名>的比较

    1: /// <summary> 2: /// 对比两个同类型的泛型集合并返回差异泛型集合 3: /// </summary> 4: /// <typeparam nam ...

  8. [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)

    ---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...

  9. java集合框架工具类Collections,集合的操作

    1 import java.util.*; public class asList { public static void main(String args[]) { // int arr[] = ...

随机推荐

  1. mongodb Enable Auth

    启动mongodb没有使用通道控制 mongod --port 27017 --dbpath /data/db1 连接mongo mongo --port 27017 创建用户 use admin d ...

  2. Litepal【开源数据库ORM框架】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 好用的数据库框架. 效果图 代码分析 本篇主要是整理Litepal的引入和增删改查的简单操作,具体使用请阅读参考资料. 使用步骤 一 ...

  3. AndroidManifest设置android:allowBackup="false"报错

    概述 设置android:allowBackup="false"的必要性 Android API Level 8及其以上Android系统提供了为应用程序数据的备份和恢复功能,此功 ...

  4. Maven常用命令:

    Maven库: http://repo2.maven.org/maven2/ Maven依赖查询: http://mvnrepository.com/ 一,Maven常用命令: 1. 创建Maven的 ...

  5. java编程行业微信群,无论新手老手欢迎加入,会一直更新

    纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群 纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群

  6. OA发展史:由点到生态

    在当今无边界组织的商业背景下,企业与员工关系已经转化为联盟关系,以往通过工作场所.劳动合同等约束的形式已经逐步弱化,管理行为空前复杂,OA正是将一个个散点整合起来的看不见的手.那么,推动OA发展的核心 ...

  7. 数据结构系列(4)之 B 树

    本文将主要讲述另一种树形结构,B 树:B 树是一种多路平衡查找树,但是可以将其理解为是由二叉查找树合并而来:它主要用于在不同存储介质之间查找数据的时候,减少 I/O 次数(因为一次读一个节点,可以读取 ...

  8. C# winForm 窗口跳转后关闭上一个窗口的方法

    FrmMain main = new FrmMain(); main.Owner = this; this.Hide(); main.ShowDialog(); Application.ExitThr ...

  9. 基础知识:if判断、while循环、for循环

    今日学习内容                   1.if 判断(流程控制的一种) 写重复的代码是程序员最不耻的行为,所以我们需要while循环和for循环 ,^_^!                 ...

  10. GraphQL基础篇

    最近参与了一个大型项目,大型项目随着系统业务量的增大,不同的应用和系统共同使用着许多的服务接口API,而随着业务的变化和发展,不同的应用对相同资源的不同使用方法最终会导致需要维护的服务API数量呈现爆 ...