scala基础学习(数据类型)-集合

news/2025/1/14 9:39:55/

文章目录

  • 集合
    • 创建集合
    • isEmpty
    • 获取数据
    • 添加元素
    • 删除元素
    • 常见方法
    • 交集 &
    • 差集 diff --
    • 并集 ++ union
    • to string
    • to list
    • to Array
    • to Map
    • 其余常用方法

集合

Scala Set(集合)是没有重复的对象集合,所有的元素都是唯一的。

Scala 集合分为可变的和不可变的集合。

默认情况下,Scala 使用的是不可变集合,如果你想使用可变集合,需要引用 scala.collection.mutable.Set 包。

默认引用 scala.collection.immutable.Set,不可变集合实例如下:

创建集合

scala">val set1:Set[Int] = Set(1,2,3,4)
println(set1)

isEmpty

scala">// 判断是否为为空
println(set1.isEmpty) //false

获取数据

  • 用过索引获取
  • 提取列表头:head,提取列表尾:last ,返回元素
  • 从前提取元素:take,从后提取元素:takeRight,返回列表
scala">//返回集合第一个元素
println(set1.head)
println(set1.last)
//1
//4// 获取集合
println(set1.take(2))
println(set1.takeRight(2))
//Set(1, 2)
//Set(3, 4)

添加元素

scala">// 添加元素
var newset = set1 + 6
println(newset)
//Set(1, 6, 2, 3, 4)// 删除元素,元素不存在无影响
val newset2 = set1 - 99
println(newset2)
//Set(1, 2, 3, 4)// 连接集合(并集)
println(set1++Set(1,7))
//Set(1, 2, 7, 3, 4)

删除元素

实际就是,获取剩余元素新列表,并不是删除

  • 删除头部元素,得到其余元素,tail

  • 删除尾部元素,得到其余元素,init

  • 删除前n个元素drop

  • 删除后n个元素dropRight

scala">println(set1.init)
println(set1.tail)
//Set(1, 2, 3)
//Set(2, 3, 4)// 参数是选取的个数
println(set1.drop(2))
println(set1.dropRight(2))
//Set(3, 4)
//Set(1, 2)

常见方法

filter,map,reduce,fold,dropWhile,find,forall,…,含义方式同其余容器

交集 &

效果都相同返回新集合

scala">println(Set(1,2,3) & Set(1,4,5))
println(Set(1,2,3).&(Set(1,4,5)))
println(Set(1,2,3).intersect(Set(1,4,5)))
println(Set(1,2,3) intersect Set(1,4,5))//Set(1)

差集 diff –

a -- b,a对b的差集

scala">// 差集
println(Set(1, 2, 3)--Set(1, 4, 5))
println(Set(1, 2, 3) diff Set(1, 4, 5))

并集 ++ union

scala">println(Set(1,2,3,4).subsetOf(Set(1,2,3,4,5)),"ldsx")

to string

scala">// to string
import scala.collection.mutable.StringBuilder
val sb = new StringBuilder
set1.addString(sb, ", ")
println(sb)
val result = sb.toString
println(result)// to string
println(set1.toString())// to string
println(set1.mkString(","))

to list

scala">println(set1.toList)

to Array

scala">println(set1.toArray)

to Map

scala">println(set1.map(key => (key, key * key)))
println(set1.map(key => (key, "1"+key)))
println(set1.map(key => (key, key * key)).toMap)

其余常用方法

方法同其余容器类型数据

head,last      
take,takeRight init,tail
drop dropRightfold,reduce,sum
dropWhile,forall,foreach

http://www.ppmy.cn/news/1562998.html

相关文章

深入理解计算机系统阅读笔记-第十二章

第12章 网络编程 12.1 客户端-服务器编程模型 每个网络应用都是基于客户端-服务器模型的。根据这个模型,一个应用时由一个服务器进程和一个或者多个客户端进程组成。服务器管理某种资源,并且通过操作这种资源来为它的客户端提供某种服务。例如&#xf…

【设计模式】工厂方法

工厂方法设计模式引入 定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类。 工厂方法设计模式分为简单工厂、工厂方法和抽象工厂三个小类。以咖啡店点餐系统为案例展开讲解。咖啡店点餐系统初始设计包含咖啡类&#xff0…

Oracle Dataguard(主库为双节点集群)配置详解(4):配置备库

Oracle Dataguard(主库为双节点集群)配置详解(4):配置备库 目录 Oracle Dataguard(主库为双节点集群)配置详解(4):配置备库一、为备库配置静态监听1、配置 li…

Kafka优势剖析-流处理集成

目录 1. Kafka Streams API 1.1 什么是 Kafka Streams API? 1.2 Kafka Streams 的工作原理 1.3 Kafka Streams 的优势 1.4 Kafka Streams 的典型应用场景 2. KSQL 2.1 什么是 KSQL? 2.2 KSQL 的工作原理 2.3 KSQL 的优势 Kafka 的流处理能力是其…

【物流管理系统 - IDEAJavaSwingMySQL】基于Java实现的物流管理系统导入IDEA教程

有问题请留言或私信 步骤 下载项目源码:项目源码 解压项目源码到本地 打开IDEA 左上角:文件 → 新建 → 来自现有源代码的项目 找到解压在本地的项目源代码文件,点击确定,根据图示步骤继续导入项目 查看项目目录&#xff…

Redis十大数据类型详解

Redis(一) 十大数据类型 redis字符串(String) string是redis最基本的类型,一个key对应一个value string类型是二进制安全的,意思是redis的string可以包含任何数据。例如说是jpg图片或者序列化对象 一个re…

02.05、链表求和

02.05、[中等] 链表求和 1、题目描述 给定两个用链表表示的整数,每个节点包含一个数位。 这些数位是反向存放的,也就是个位排在链表首部。 编写函数对这两个整数求和,并用链表形式返回结果。 2、解题思路 本题要求对两个链表表示的整数…

反弹SHELL不回显带外正反向连接防火墙出入站文件下载

什么是反弹shell 正向连接正向连接(Forward Connection):正向连接是一种常见的网络通信模式,其中客户端主动发起连接到服务器或目标系统。正向连接通常用于客户端-服务器通信,客户端主动请求服务或资源,例如…