前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Scala 集合

Scala 集合

作者头像
Freedom123
发布2024-03-29 09:40:38
640
发布2024-03-29 09:40:38
举报
文章被收录于专栏:DevOpsDevOps

一. 集合

1.列表 List
代码语言:javascript
复制
scala> val numbers = List(1, 2, 3, 4)
numbers: List[Int] = List(1, 2, 3, 4)
2.集 Set
代码语言:javascript
复制
scala> Set(1, 1, 2)
res0: scala.collection.immutable.Set[Int] = Set(1, 2)
3.元组 Tuple

元组是在不使用类的前提下,将元素组合起来形成简单的逻辑集合。

代码语言:javascript
复制
scala> val hostPort = ("localhost", 80)
hostPort: (String, Int) = (localhost, 80)

scala> hostPort._1
res0: String = localhost

scala> hostPort._2
res1: Int = 80
4.映射 Map
代码语言:javascript
复制
Map(1 -> 2)
Map("foo" -> "bar")
5.选项 Option

Option 是一个表示有可能包含值的容器。 Option 本身是泛型的,并且有两个子类: Some[T] 或 None

代码语言:javascript
复制
scala> val numbers = Map("one" -> 1, "two" -> 2)
numbers: scala.collection.immutable.Map[java.lang.String,Int] = Map(one -> 1, two -> 2)

scala> numbers.get("two")
res0: Option[Int] = Some(2)

scala> numbers.get("three")
res1: Option[Int] = None

// We want to multiply the number by two, otherwise return 0.
val result = if (res1.isDefined) {
  res1.get * 2
} else {
  0
}

二. 函数组合子

1. map
代码语言:javascript
复制
scala> numbers.map((i: Int) => i * 2)
res0: List[Int] = List(2, 4, 6, 8)

//或传入一个部分应用函数
scala> def timesTwo(i: Int): Int = i * 2
timesTwo: (i: Int)Int

scala> numbers.map(timesTwo _)
res0: List[Int] = List(2, 4, 6, 8)
2.foreach
代码语言:javascript
复制
scala> numbers.foreach((i: Int) => i * 2)
3. filter
代码语言:javascript
复制
scala> numbers.filter((i: Int) => i % 2 == 0)
res0: List[Int] = List(2, 4)
scala> def isEven(i: Int): Boolean = i % 2 == 0
isEven: (i: Int)Boolean

scala> numbers.filter(isEven _)
res2: List[Int] = List(2, 4)
4. zip

zip 将两个列表的内容聚合到一个对偶列表中

代码语言:javascript
复制
scala> List(1, 2, 3).zip(List("a", "b", "c"))
res0: List[(Int, String)] = List((1,a), (2,b), (3,c))
5. partition

partition 将使用给定的谓词函数分割列表。

代码语言:javascript
复制
scala> val numbers = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
scala> numbers.partition(_ % 2 == 0)
res0: (List[Int], List[Int]) = (List(2, 4, 6, 8, 10),List(1, 3, 5, 7, 9))
6. find
代码语言:javascript
复制
scala> numbers.find((i: Int) => i > 5)
res0: Option[Int] = Some(6)
7. drop & dropWhile

dropWhile 将删除元素直到找到第一个匹配谓词函数的元素。例如,如果我们在 numbers 列表上使用 dropWhile 奇数的函数, 1 将被丢弃(但 3 不会被丢弃,因为他被 2 “保护”了)。

代码语言:javascript
复制
scala> numbers.drop(5)
res0: List[Int] = List(6, 7, 8, 9, 10)

scala> numbers.dropWhile(_ % 2 != 0)
res0: List[Int] = List(2, 3, 4, 5, 6, 7, 8, 9, 10)
8.foldLeft & foldRight
代码语言:javascript
复制
scala> numbers.foldLeft(0)((m: Int, n: Int) => m + n)
res0: Int = 55

scala> numbers.foldLeft(0) { (m: Int, n: Int) => println("m: " + m + " n: " + n); m + n }
m: 0 n: 1
m: 1 n: 2
m: 3 n: 3
m: 6 n: 4
m: 10 n: 5
m: 15 n: 6
m: 21 n: 7
m: 28 n: 8
m: 36 n: 9
m: 45 n: 10
res0: Int = 55
9.flatten

flatten 将嵌套结构扁平化为一个层次的集合。

代码语言:javascript
复制
scala> List(List(1, 2), List(3, 4)).flatten
res0: List[Int] = List(1, 2, 3, 4)
10.flatMap

flatMap 是一种常用的组合子,结合映射 [mapping] 和扁平化 [flattening]。flatMap 需要一个处理嵌套列表的函数,然后将结果串连起来

代码语言:javascript
复制
scala> val nestedNumbers = List(List(1, 2), List(3, 4))
nestedNumbers: List[List[Int]] = List(List(1, 2), List(3, 4))

scala> nestedNumbers.flatMap(x => x.map(_ * 2))
res0: List[Int] = List(2, 4, 6, 8)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-03-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一. 集合
    • 1.列表 List
      • 2.集 Set
        • 3.元组 Tuple
          • 4.映射 Map
            • 5.选项 Option
            • 二. 函数组合子
              • 1. map
                • 2.foreach
                  • 3. filter
                    • 4. zip
                      • 5. partition
                        • 6. find
                          • 7. drop & dropWhile
                            • 8.foldLeft & foldRight
                              • 9.flatten
                                • 10.flatMap
                                相关产品与服务
                                容器服务
                                腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                                领券
                                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档