scala的多种集合的使用(2)之集合常用方法
一、常用的集合方法
1.可遍历集合的常用方法
下表列出了Traverable在所有集合常用的方法。接下来的符号:
c代表一个集合
f代表一个函数
p代表一个谓词
n代表一个数字
op代表一个简单的操作(通常是一个简单的函数)



2.可变的集合方法
下表里的是可变集合常用的操作符:

3.不可变的集合方法
注意不可变集合不可被修改,所以在第一行的每个表达式的结果必须赋给一个新变量。
| 操作符 | 描述 |
| c1 ++ c2 | 把c2集合的元素附加到c1里创造一个新的集合 |
scala> val c1 = Vector(1,2,3,4,5)
c1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> val c2 = Vector(6,7,8)
c2: scala.collection.immutable.Vector[Int] = Vector(6, 7, 8) scala> c1 ++ c2
res35: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5, 6, 7, 8)
| 操作符 | 描述 |
| c :+ e | 返回把元素e附加到集合c的新集合 |
scala> val v1 = Vector(1,2,3,4,5)
c1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> val e = 10
e: Int = 10 scala> v1 :+ e
res38: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5, 10)
| 操作符 | 描述 |
| e +: c2 | 返回一个把元素e前插到集合c的新集合 |
scala> val v1 = Vector(1,2,3,4,5)
c1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> val e = 10
e: Int = 10 scala> e +: v1
res39: scala.collection.immutable.Vector[Int] = Vector(10, 1, 2, 3, 4, 5)
| 操作符 | 描述 |
| e :: list | 返回一个把e前插到名为list列表的集合(::只在List集合上用) |
scala> val list = List(7,8,9)
list: List[Int] = List(7, 8, 9) scala> val e = 10
e: Int = 10 scala> e :: list
res75: List[Int] = List(10, 7, 8, 9)
| 操作符 | 描述 |
| c drop n | 把c2集合的元素附加到c1里创造一个新的集合 |
scala> val v1 = Vector(1,2,3,4,5)
v1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> val n = 3
n: Int = 3 scala> v1 drop n
res1: scala.collection.immutable.Vector[Int] = Vector(4, 5)
| 操作符 | 描述 |
| c1 take n | 把集合的前两个元素列出来 |
scala> val c1 = Vector(1,2,3,4,5)
c1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> c1 take 2
res82: scala.collection.immutable.Vector[Int] = Vector(1, 2)
4.可变和不可变的map的常用方法
m代表一个不可变map
mm代表一个可变的map
k代表一个键
v代表一个值
p代表一个谓词
c代表一个集合
如果是var修饰,引用可变,支持读写。
如果是val修饰,引用不可变,支持读写。
| 操作符 | 描述 |
| m - k | 返回删除key(以及相应的value的值)后的map |
scala> val v1 = Vector(1,2,3,4,5)
v1: scala.collection.immutable.Vector[Int] = Vector(1, 2, 3, 4, 5) scala> val map = Map(1 -> "a",2 -> "b",3 -> "c")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c) scala> map - 1
res5: scala.collection.immutable.Map[Int,String] = Map(2 -> b, 3 -> c)
| 操作符 | 描述 |
| m - (k1,k2,k3) | 返回删除k1,k2,k3后的map |
scala> val map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d",5 -> "e",6 -> "f")
map: scala.collection.immutable.Map[Int,String] = Map(5 -> e, 1 -> a, 6 -> f, 2-> b, 3 -> c, 4 -> d) scala> map - (1,3,5)
res6: scala.collection.immutable.Map[Int,String] = Map(6 -> f, 2 -> b, 4 -> d)
| 操作符 | 描述 |
| m -- c | 返回删除key后的map,c是指集合 |
scala> val map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d",5 -> "e",6 -> "f")
map: scala.collection.immutable.Map[Int,String] = Map(5 -> e, 1 -> a, 6 -> f, 2-> b, 3 -> c, 4 -> d) scala> val c = Vector(1,3,5)
c: scala.collection.immutable.Vector[Int] = Vector(1, 3, 5) scala> map -- c
res7: scala.collection.immutable.Map[Int,String] = Map(6 -> f, 2 -> b, 4 -> d)
| 操作符 | 描述 |
| m -- List(k1,k2) | 返回删除key后的map |
1
scala> val map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d",5 -> "e",6 -> "f")
map: scala.collection.immutable.Map[Int,String] = Map(5 -> e, 1 -> a, 6 -> f, 2-> b, 3 -> c, 4 -> d) scala> val list = List(1,3,5)
list: List[Int] = List(1, 3, 5) scala> map -- list
res8: scala.collection.immutable.Map[Int,String] = Map(6 -> f, 2 -> b, 4 -> d)
2
scala> val map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d",5 -> "e",6 -> "f")
map: scala.collection.immutable.Map[Int,String] = Map(5 -> e, 1 -> a, 6 -> f, 2
-> b, 3 -> c, 4 -> d) scala> map -- List(1,2,3)
res9: scala.collection.immutable.Map[Int,String] = Map(5 -> e, 6 -> f, 4 -> d)
| 操作符 | 描述 |
| m(k) | 返回k的value |
scala> var map = Map(1 -> 1,2 -> 2,3 -> 3,4 -> 4)
map: scala.collection.immutable.Map[Int,Int] = Map(1 -> 1, 2 -> 2, 3 -> 3, 4 ->4) scala> map(2)
res34: Int = 2
| 操作符 | 描述 |
| m contains k | 如果map包含k则返回true |
scala> var map = Map(1 -> 1,2 -> 2,3 -> 3,4 -> 4)
map: scala.collection.immutable.Map[Int,Int] = Map(1 -> 1, 2 -> 2, 3 -> 3, 4 ->4) scala> map contains 3
res36: Boolean = true
| 操作符 | 描述 |
| m get k | 如果k存在返回Some[A]作为key的值,否则None |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map get 2
res44: Option[String] = Some(b) scala> map get 5
res45: Option[String] = None
| 操作符 | 描述 |
| m getOrElse(k,d) | 如果k找到的话,返回k的值,否则返回默认值d |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map getOrElse(2,"hello")
res46: String = b scala> map getOrElse(5,"hello")
res47: String = hello
| 操作符 | 描述 |
| m isDefinedAt k | 如果map包含k则返回true |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map isDefinedAt 2
res48: Boolean = true scala> map isDefinedAt 5
res49: Boolean = false
| 操作符 | 描述 |
| m keys | 把map中的keys作为Iterable返回 |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map keys
warning: there was one feature warning; re-run with -feature for details
res50: Iterable[Int] = Set(1, 2, 3, 4)
| 操作符 | 描述 |
| m keySet | 把map中的keys作为Set返回 |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map keySet
warning: there was one feature warning; re-run with -feature for details
res54: scala.collection.immutable.Set[Int] = Set(1, 2, 3, 4)
| 操作符 | 描述 |
| m values | 把map中的value作为Iterable返回 |
scala> var map = Map(1 -> "a",2 -> "b",3 -> "c",4 -> "d")
map: scala.collection.immutable.Map[Int,String] = Map(1 -> a, 2 -> b, 3 -> c, 4-> d) scala> map values
warning: there was one feature warning; re-run with -feature for details
res56: Iterable[String] = MapLike(a, b, c, d)
二、在创建集合时声明一个类型
想要创建一个混合型的集合,scala不会自动分配想要的类型。
创建一个手动的集合如下:
scala> trait Animal
defined trait Animal scala> trait FurryAnimal extends Animal
defined trait FurryAnimal scala> case class Dog(name: String) extends Animal
defined class Dog scala> case class Cat(name: String) extends Animal
defined class Cat scala> val x = Array(Dog("Fido"),Cat("Felix"))
x: Array[Product with Serializable with Animal] = Array(Dog(Fido), Cat(Felix))
如上所示,scala给product指定了Serializable和Animal类型。如果想要一个Array[Animal],手动需要指定类型:
scala> val x = Array[Animal](Dog("Fido"),Cat("Felix"))
x: Array[Animal] = Array(Dog(Fido), Cat(Felix))
三、可变变量集合与不可变量集合
但把一个不可变的Vector赋给一个可变的var时,似乎可以给它添加元素。
scala> var sisters = Vector("Melinda")
sisters: scala.collection.immutable.Vector[String] = Vector(Melinda)
scala> sisters = sisters :+ "Melissa"
sisters: scala.collection.immutable.Vector[String] = Vector(Melinda, Melissa)
scala> sisters = sisters :+ "Marisa"
sisters: scala.collection.immutable.Vector[String] = Vector(Melinda, Melissa, Ma
risa)
scala> sisters.foreach(println)
Melinda
Melissa
Marisa
尽管你看起来改变了一个不可改变的集合,但实际上是每次用:+方法时sisters变量会指向一个新的集合。sisters变量是可变的,所以每次执行时相当于重新赋值一个新的集合。
总结:
- 一个可变的变量var可以被赋予一个新的数据。
- 一个不可变的变量val就如java中的final变量,不可能被重新赋值。
- 在可变集合的元素中可以被改变(ArrayBuffer)。
- 在不可被改变的集合元素中不可被改变(Vector)。
scala的多种集合的使用(2)之集合常用方法的更多相关文章
- scala的多种集合的使用(1)之集合层级结构与分类
一.在使用scala集合时有几个概念必须知道: 1.谓词是什么? 谓词就是一个方法,一个函数或者一个匿名函数,接受一个或多个函数,返回一个Boolean值. 例如:下面方法返回true或者false, ...
- Scala学习之路 (四)Scala的数组、映射、元组、集合
一.数组 1.定长数组和变长数组 import scala.collection.mutable.ArrayBuffer object TestScala { def main(args: Array ...
- 牛客网Java刷题知识点之Java 集合框架的构成、集合框架中的迭代器Iterator、集合框架中的集合接口Collection(List和Set)、集合框架中的Map集合
不多说,直接上干货! 集合框架中包含了大量集合接口.这些接口的实现类和操作它们的算法. 集合容器因为内部的数据结构不同,有多种具体容器. 不断的向上抽取,就形成了集合框架. Map是一次添加一对元素. ...
- 背水一战 Windows 10 (22) - 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合
[源码下载] 背水一战 Windows 10 (22) - 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合 作 ...
- 【ASP.NET实战教程】ASP.NET实战教程大集合,各种项目实战集合
[ASP.NET实战教程]ASP.NET实战教程大集合,各种项目实战集合,希望大家可以好好学习教程中,有的比较老了,但是一直很经典!!!!论坛中很多小伙伴说.net没有实战教程学习,所以小编连夜搜集整 ...
- 绑定: 通过 Binding 绑定对象, 通过 x:Bind 绑定对象, 通过 Binding 绑定集合, 通过 x:Bind 绑定集合
背水一战 Windows 10 之 绑定 通过 Binding 绑定对象 通过 x:Bind 绑定对象 通过 Binding 绑定集合 通过 x:Bind 绑定集合 示例1.演示如何通过 Bindin ...
- 对比两个同类型的泛型集合并返回差异泛型集合 ——两个List<类名>的比较
1: /// <summary> 2: /// 对比两个同类型的泛型集合并返回差异泛型集合 3: /// </summary> 4: /// <typeparam nam ...
- [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)
---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...
- java集合框架工具类Collections,集合的操作
1 import java.util.*; public class asList { public static void main(String args[]) { // int arr[] = ...
随机推荐
- oracle 一些常用的sql优化规则
1.高效使用groupby 提高GROUP BY语句的效率,可以通过将不需要的记录在GROUP BY之前过滤掉. 低效: SELECT JOB ,AVG(SAL) FROM EMP GROUP BY ...
- Entity Framework Core 2.1,添加种子数据
EFCore 2.1出来有一段时间了,里面的新功能还没怎么用,今天研究下如何使用EF Core 2.1添加种子数据. 这部分的官方文档地址是:https://docs.microsoft.com/en ...
- NetStateReceiver【监听网路状态变化】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 用来监控网络变化时的处理,一般用来toast提示或者扩展为其他作用. 效果图 代码分析 NetStateReceiver:网络 ...
- Windows10下安装Docker的步骤
一.启用Hyper-V 打开控制面板 - 程序和功能 - 启用或关闭Windows功能,勾选Hyper-V,然后点击确定即可,如图: 点击确定后,启用完毕会提示重启系统,我们可以稍后再重启. 二.安装 ...
- Cortex-M 实现互斥操作的三种方法
注:本文仅针对Cortex-M3/4 系列进行讲述. 在传统的ARM处理器架构中,常使用SWP指令来实现锁的读/写原子操作,但从ARM v6开始,读/写访问在独立的两条总线上进行,SWP指令已无法在此 ...
- 时序数据库连载系列:指标届的独角兽Prometheus
简介 Prometheus是SoundCloud公司开发的一站式监控告警平台,依赖少,功能齐全.于2016年加入CNCF,广泛用于 Kubernetes集群的监控系统中,2018.8月成为继K8S之后 ...
- Docker最全教程之树莓派和Docker(十五)
前言 树莓派(Raspberry Pi)是一台卡片电脑(只有信用卡大小),我们可以使用树莓派做很多事情,比如智能家居的中控.航空器.BT下载器.挖矿机.智能机器人.小型服务器(花生壳+网站)等等. 目 ...
- .NET Core:多样的宿主
.NET Core 可以以以下方式作为宿主运行: IIS 控制台 Windows服务 运行启动代码: public static void Main(string[] args) ...
- SQL Server 一列或多列重复数据的查询,删除(转载)
转载来源:https://www.cnblogs.com/sunxi/p/4572332.html 业务需求 最近给公司做一个小工具,把某个数据库(数据源)的数据导进另一个数据(目标数据库).要求导入 ...
- 回顾曾经的自己,献给java初学者的建议
要不惜代价投资自己,任何对自己的投资都是值得的 要多学习数据结构, 习惯看源码! 一份知识经过n个人的传递早已经不成样子了 遇到问题不要直接百度,百度上那些花里胡哨的东西有用的很少,对症下药才是王道, ...
