当前位置: 首页 > news >正文

Scala之集合(1)

目录

​​​​​​​集合介绍:

不可变集合继承图:​编辑

 可变集合继承图

数组:

不可变数组:

样例代码:

遍历集合的方法:

1.for循环

2.迭代器

3.转换成List列表:

4.使用foreach()函数:

可变数组:

ArrayBuffer:

二维数组:

 List集合:

Set 集合:

不可变 Set:

可变Set:

Map集合:

创建map:

map集合的遍历:

可变map:

元组:

tuple的定义:

元组与map的关系:

特点:

集合介绍:

1)Scala 的集合有三大类:序列 Seq、集 Set、映射 Map,所有的集合都扩展自 Iterable  
特质
2)对于几乎所有的集合类,Scala 都同时提供了可变不可变的版本,分别位于以下两
个包
不可变集合:scala.collection.immutable
可变集合: scala.collection.mutable
3Scala 不可变集合,就是指该集合对象不可修改,每次修改就会返回一个新对象,而
不会对原对象进行修改。类似于 java 中的 String 对象
4)可变集合,就是这个集合可以直接对原对象进行修改,而不会返回新的对象。类似
java StringBuilder 对象

不可变集合:

不可变集合继承图:

set集合特点:无序,不重复

对set集合无序的理解:set集合的无序是指在使用append等方法给集合添加元素的时候所添加的元素的顺序是不可预测的,并且不能按照添加顺序进行遍历(存储位置是不一定的)

Set集合的无序性是由它的实现方式所决定的。通常,Set集合的实现方式采用了哈希表这种数据结构,其中元素被散列到桶中,不同的元素可能被散列到同一个桶中,因此添加的顺序不能保证元素的顺序。

set集合提供了SortedSet集合是有序的(放入2,3,1,4会按照1,2,3,4进行存储)SortedSet写了一个TreeSet集合是树状存储

Seq Java 没有的,我们发现 List 归属到 Seq 了,因此这里的 List 就和 Java 不是同一个
概念了
我们前面的 for 循环有一个 1 to 3,就是 IndexedSeq 下的 Range
我们发现经典的数据结构比如 Queue(队列) Stack (栈)被归属到 LinearSeq(线性序列)
IndexedSeq LinearSeq 的区别:
1IndexedSeq 是通过索引来查找和定位(相当于数组,通过下标查找),因此速度快,比如 String 就是一个索引集
合,通过索引即可定位
2LinearSeq 是线型的,即有头尾的概念,这种数据结构一般是通过遍历来查找

 可变集合继承图

数组:

不可变数组:

不可变集合是长度不可变

Scala中的array 是与 Java中的[]对应

样例代码:

package chapter05
object Test01_Array {def main(args: Array[String]): Unit = {val array = new Array[Int](4)array(3)=100//遍历for (elem <- array) {println(elem)}}
}

在Scala中没有写方法名的都是调用了apply方法

遍历集合的方法:

1.for循环

        上边样例代码已经使用

2.迭代器

        迭代器相当于是指针的跳转(指针在内存中的跳转)

样例代码:

package chapter05
object Test01_Array {def main(args: Array[String]): Unit = {val array = new Array[Int](4)array(3)=100
val iterator: Iterator[Int] = array.iteratorwhile (iterator.hasNext){val i: Int = iterator.next()println(i)}}
}

3.转换成List列表:

        array集合可以通过to方法转换成List列表

4.使用foreach()函数:

在Scala中给所有的集合都提供了一个foreach()方法 进行函数式打印

foreach()源码:

def foreach[U](f: A => U): Unit = {var i = 0val len = lengthwhile (i < len) { f(this(i)); i += 1 }}

源码分析:

foreach()传入的参数实际是传入的函数

A:是代表你传入集合的类型

U:是泛型,代表你的输出类型

这个函数的返回值是Unit类型

让后通过while进行向下运行

对foreach()函数的调用使用匿名函数进行调用

  array.foreach(i=>println(i*2))

可变数组:

数组是默认的不可变的,如果需要可变是需要自己导包的

ArrayBuffer:

填入的初始化大小(数组的大小) 只决定了创建底层结构的长度(不填的话默认是16)

ArrayBuffer是可以进行添加元素的append()

可以进行增删改查

可变数组与不可变数组元素的增加区别:

可变的用方法不可变的用符号

代码样例:

可变数组的增删改查:

package chapter05
import scala.collection.mutable.ArrayBuffer
object Test_02_ArrayBuffer {def main(args: Array[String]): Unit = {//可变---导包val arrayBuffer = new ArrayBuffer[Int](4)arrayBuffer.append(1,2,3)arrayBuffer.remove(1)arrayBuffer.update(0,100)println(arrayBuffer(0))println(arrayBuffer)}
}

不可变数组是不可变的,如果使用符号做出改变会生成一个新的对象

val array = new Array[Int](10)val array1: Array[Int]= array :+ 8println(array1.toList)

使用to方法可以让可变与不可变数组进行相互转换

二维数组:

二维数组的定义与遍历:

   val array2: Array[ Array[Int]] = Array(Array(1, 2, 3),Array(1, 2, 3),Array(1, 2, 3))for (array3 <- array2) {for (elem <- array3) {print(elem+ "\t")}println()}

在Scala中创建多维数组的方法:

    val array3: Array[Array[Int]] = Array.ofDim[Int](3, 4)

 List集合:

List是一个抽象类 在不继承的情况下是无法new的,所以需要使用伴生对象的apply方法

直接使用即可

1List 默认为不可变集合
2)创建一个 List(数据有顺序,可重复)
    val list = List(1, 2, 3, 4)
3)遍历 List
list.foreach(println)
4List 增加数据
由继承图可知 List集合为链表下边的类  链表添加数据有头插法和尾插法之分 
        (不可变集合用符号) 
尾插:
 val ints: List[Int] = list :+ 10ints.foreach(println)
头插:
    val list1: List[Int] = 10 :: listlist1.foreach(println)
5)集合间合并:将一个整体拆成一个一个的个体,称为扁平化
扁平化是把两个集合的数据进行打散,然后进行连接合并
  val list2 = List(5, 6, 7, 8)val ints1: List[Int] = list ::: list2println(ints1)
                                   
6)取指定数据
    println(ints1(5))
7)空集合 Nil
     Nil是一个空集合,相当于创建一个空的List,他是一个单独的对象
val ints2: List[Int] = 1 :: 2 :: 4 :: 5 :: Nil
val ints3: List[Int] = 3 :: 6 :: 7 :: 9 :: List()

上述两行代码代表的是一个意思

ListBuffer:
ListBuffer是一个可变的集合
可变集合是可变的,调用使用函数,需要导包

Set 集合:

        默认情况下,Scala 使用的是不可变集合,如果你想使用可变集合,需要引用
scala.collection.mutable.Set
set集合其实是一个特质,需要直接调用apply方法创建对象(省略函数名)

不可变 Set:

 
1Set 默认是不可变集合,数据无序
2)数据不可重复(set集合的使用场景---->去重)
 val value: Any = Set(1, 1, 2,2,3, 4, 5, 6, 7, 8, 9)println(value)

运行结果:

判断set的类型:

 val bool: Boolean = value.isInstanceOf[HashSet[Int]]println(bool)
set集合默认时使用HashSet集合的,只有在数据元素的个数小于等于4个的时候才会使用特殊的set集合

可变Set:

在写可变set的时候,添加mutable.set
创建语句:
    val ints: mutable.Set[Int] = mutable.Set(1, 2, 2, 3, 1, 4, 5, 6, 8, 7, 9)

可变Set的增加是add方法,不是append方法

可变Set的集合也是符合不可重复,不可修改的特点

 只可增删查

Map集合:

map集合也是一个特质,可以通过apply方法创建对象

map是一个(k,v)集合

创建map:

(1)这是一种采用元组的方式创建的

    val map = Map(("hello", 10), ("world", 20))

(2)这是采用的箭头的方式创建的

    val map1 = Map("hello" -> 10, "world" -> 12)

常用第一种方式创建

map集合的遍历:

(采用第一种方式创建的)

for循环得到的对象是元组

    for (elem <- map) {//elem是元组val key: String = elem._1val value: Int = elem._2println(s"${key}:${value}")}

在Scala中value的类型为Int类型  在Java中是Int的包装类(防止在get方法找value不存在的时候为Null的情况)

上述情况也会在Scala中出现,Scala是对get方法使用Option(是一个抽象类,被两个子类实现(None,Some))封装

如果get的key存在 就调用上述的some类 再对结果进行调用get  转换成int类型 (方法很长,而且在没有值的情况下是会报错的)

因为太长引入了新的写法:

对map集合直接调用getOrElse(1)方法   设置1  有值输出值  无值输出1

    val i: Int = map.getOrElse("hello", 1)println(i)

不存在就会返回None

可变map:

可变map也是采用mutable.map进行创建

增删改查:

增加:

put方法  这个方法可以增加也可以进行修改   当key值存在的时候  如果value不同会覆盖前值

  val maybeInt: Option[Int] = map.put("helloi2", 23)

删除:

    val maybeInt1: Option[Int] = map.remove("hello")

查找:

查找与不可变一样使用getOrElse方法进行查找

元组:

本身为不可变 ,可以存放不同数据类型的元素

list具有上述的性质    但是使用list存放不同类型的数据 在调用的时候无法得到相应的类型(统一为Any)而tuple(元组可以)

tuple的定义:

    val tuple: (String, Int) = ("hihihi", 23)

元组与map的关系:

map中的(key  value )元素被默认当作二元组

特点:

这样我们可以实现list集合与map集合的转换

    val toList: List[(String, Int)] = map1.toListprintln(toList)

 运行结果:

 

相关文章:

Scala之集合(1)

目录 ​​​​​​​集合介绍&#xff1a; 不可变集合继承图&#xff1a;​编辑 可变集合继承图 数组&#xff1a; 不可变数组&#xff1a; 样例代码&#xff1a; 遍历集合的方法&#xff1a; 1.for循环 2.迭代器 3.转换成List列表&#xff1a; 4.使用foreach()函数&a…...

公网使用SSH远程登录macOS服务器【内网穿透】

文章目录前言1. macOS打开远程登录2. 局域网内测试ssh远程3. 公网ssh远程连接macOS3.1 macOS安装配置cpolar3.2 获取ssh隧道公网地址3.3 测试公网ssh远程连接macOS4. 配置公网固定TCP地址4.1 保留一个固定TCP端口地址4.2 配置固定TCP端口地址5. 使用固定TCP端口地址ssh远程前言…...

PVE相关的各种一键脚本(一键安装PVE)(一键开设KVM虚拟化的NAT服务器-自带内外网端口转发)

PVE 原始仓库&#xff1a;https://github.com/spiritLHLS/pve 前言 建议debian在使用前尽量使用最新的系统 非debian11可使用 debian一键升级 来升级系统 当然不使用最新的debian系统也没问题&#xff0c;只不过得不到官方支持 请确保使用前机器可以重装系统&#xff0c;…...

CSDN目录博客(zhaoshuangjian)

总目录 一、Java1.1 高并发1.2 多线程1.3 集合1.4 I/O1.5 异常1.6 事务1.7 锁机制1.8 JVM 二、数据库2.1 mysql2.1.1 mysql索引2.1.1 mysql锁2.1.1 mysql事务2.1.1 2.2 oracle2.3 postgresql2.4 达梦2.5 人大金仓kingbase 三、设计模式四、中间件4.1 缓存中间件-redis4.2 缓存中…...

uniapp人脸识别解决方案

APP端&#xff1a; 因为APP端无法使用uni的camera组件&#xff0c;最开始考虑使用内嵌webview的方式&#xff0c;通过原生dom调用video渲染画面然后通过canvas截图。但是此方案兼容性在ios几乎为0&#xff0c;如果app只考虑安卓端的话可以采用此方案。后面又想用live-pusher组件…...

hashlib模块

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起探讨和分享Linux C/C/Python/Shell编程、机器人技术、机器学习、机器视觉、嵌入式AI相关领域的知识和技术。 hashlib模块专栏&#xff1a;《python从入门到实战》 哈希算法&#xff0c;也叫摘要算法。 加密&…...

NC65合并报表如何取消上报并退回以及注意事项和相关问题总结

NC65合并报表如何取消上报并退回&#xff1f; 在【企业绩效管理】-【合并报表】-【合并】-【合并执行】节点中&#xff0c;点击〖数据中心〗按钮&#xff0c;在弹出的〖合并报表数据中心〗界面中&#xff0c;点击〖报送管理〗-〖合并方案请求退回〗&#xff0c;然后到【合并综…...

28岁,终于从字节退休了...

大厂一直是每个程序员都向往职业目标&#xff0c;大厂意味着薪资高、福利好、倍有面儿&#xff0c;而且发展空间也大。甚至有人调侃不想进大厂的程序员不是好程序员。 而在网上&#xff0c;也有各个网友分享自己在大厂的经历&#xff0c;在某平台还有一个近2600万浏览的话题&a…...

数据的表示和存储——

目录 浮点数的编码表示 浮点数类型 ​编辑 浮点数的表示 &#xff08;1&#xff09;浮点数&#xff08;Float Point&#xff09;的表示范围 &#xff08;2&#xff09;规格化数形式 &#xff08;3&#xff09;IEEE 754标准 其他形式的机器数表示 个人总结 浮点数的编码表…...

springboot零基础到项目实战

推荐教程&#xff1a; springboot零基础到项目实战 SpringBoot这门技术课程所包含的技术点其实并不是很多&#xff0c;但是围绕着SpringBoot的周边知识&#xff0c;也就是SpringBoot整合其他技术&#xff0c;这样的知识量很大&#xff0c;例如SpringBoot整合MyBatis等等。因此…...

自媒体都在用的5个素材网站,视频、音效、图片全部免费下载~

推荐几个自媒体必备的素材库&#xff0c;免费可商用&#xff0c;建议收藏&#xff01; 1、菜鸟图库 视频素材下载_mp4视频大全 - 菜鸟图库 国内超大的素材库&#xff0c;在这里你可以找到设计、办公、图片、视频、音频等各种素材。视频素材就有上千个&#xff0c;全部都很高清…...

开放式耳机新巅峰!南卡OE Pro兼备澎湃音质、舒适佩戴、创新设计

众所周知&#xff0c;当初苹果带来TWS耳机新时代以后&#xff0c;后面有许多的蓝牙耳机相继跟随和模仿&#xff0c;但NANK南卡却独辟蹊径&#xff0c;将在近日重磅推出首款0压无感全开放无线耳机——南卡OE Pro&#xff0c;走向开放式TWS耳机的新时代。 31度黄金倾斜受力面&…...

1700页,卷S人的 Java《八股文》PDF手册,涨薪跳槽拿高薪就靠它了

大家好&#xff0c;最近有不少小伙伴在后台留言&#xff0c;又得准备面试了&#xff0c;不知道从何下手&#xff01; 不论是跳槽涨薪&#xff0c;还是学习提升&#xff01;先给自己定一个小目标&#xff0c;然后再朝着目标去努力就完事儿了&#xff01; 为了帮大家节约时间&a…...

普通人是否能从ChatGPT中分一杯羹?

ChatGPT3.0刚刚推出&#xff0c;最开始的时候&#xff0c;人们只是将ChatGPT看作一个很会聊天的机器人&#xff0c;无论问题多么天马行空&#xff0c;它的答案看上去都有理有据。后来&#xff0c;像打开潘多拉魔盒一样&#xff0c;很多人开始拿它编大纲、撰写文案、编代码、创作…...

SpringBoot自动装配原理(附面试快速答法)

文章目录SpringBoot自动装配原理1. 从调用SpringApplication构造器方法开始2. 解析启动类4.按需装配4.1 分析dubbo自动装配5. 如果定义自己的starter6. 面试答法SpringBoot自动装配原理 之前面试被问到这个题目&#xff0c;只会答一些spi、AutoConfigration注解、Import之类的&…...

如何在大厂做好架构演进?

1 架构演进的定义 1.1 定义 通过设计新的系统架构(4R)&#xff0c;来应对业务和技术的发展变化。 1.2 关键点 新架构新的复杂度 1.3 目的 应对业务和技术的发展变化后带来新的复杂度。 案例 淘宝去IOE&#xff0c;是因为业务发展大了后&#xff0c;IOE的成本和可控性难…...

减半技术实现求a的n次幂

目录 减半技术实现求a的n次幂 程序设计 程序分析 减半技术实现求a的n次幂 【问题描述】给定两个正整数a和n,采用减半技术求a的n次幂;其中a<100,b<20; 【输入形式】两个整数a,n(a与n中间用空格隔开); 【输出形式】一个整数 【样例输入1】2 3 【样例输出1】8 【样…...

MYSQL8窗口函数

MYSQL8窗口函数 MYSQL8窗口函数窗口函数分类序号函数--排行榜row_number()示例rank()示例dense_rank()示例partition by对每个分区内的行进行排名不加partition by全局排序 开窗聚合函数分布函数CUME_DIST()PERCENT_RANK() 前后函数LAG()的用法LEAD() 头尾函数其他函数NTH_VALU…...

全国大学生智能汽车竞赛——安装Ubuntu操作系统(双系统)

1.1 电脑分区 1.1.1 分区原因 由于我们想要在电脑上同时安装Windows和Ubuntu系统&#xff0c;所以就要在window使用的内存中划分出来一段用来给Ubuntu系统使用&#xff0c;相当于一个应用程序一样 1.1.2 分区步骤 1.右击此电脑&#xff0c;点击管理&#xff0c;然后双击左侧…...

[STM32F103C8T6]看门狗

看门狗&#xff1a; 在由单片机构成的微型计算机系统中&#xff0c;由于单片机的工作常常会受到来自外界电磁场的干扰&#xff0c;造 成程序的跑飞&#xff0c;而陷入死循环&#xff0c;程序的正常运行被打断&#xff0c;由单片机控制的系统无法继续工作&#xff0c;会 造成整个…...

量子同态加密:理论与实践的突破

1. 量子同态加密&#xff1a;理论与实践的桥梁量子同态加密&#xff08;Quantum Homomorphic Encryption, QHE&#xff09;是密码学领域的一项突破性技术&#xff0c;它允许在加密的量子数据上直接执行任意量子计算&#xff0c;而无需事先解密。这项技术对于构建真正隐私保护的…...

顶伯在线语音工具背后的技术力量:AI语音合成与深度学习解析

顶伯在线语音工具背后的技术力量在人工智能浪潮中&#xff0c;语音交互正成为人机沟通的核心方式。顶伯作为行业领先的在线语音工具&#xff0c;凭借自主研发的深度学习架构&#xff0c;将文字转化为高度自然的语音&#xff0c;广泛应用于有声阅读、智能客服、教育辅助等领域。…...

三星固件下载终极指南:Bifrost跨平台工具完整使用手册

三星固件下载终极指南&#xff1a;Bifrost跨平台工具完整使用手册 【免费下载链接】Bifrost Cross-platform tool for downloading Samsung mobile device firmware. 项目地址: https://gitcode.com/gh_mirrors/sa/Bifrost 还在为三星设备找不到官方固件而烦恼吗&#x…...

C语言编程入门:从变量、运算符到控制流与实战计算器

1. 项目概述&#xff1a;为什么C语言是程序员的“内功心法”&#xff1f;如果你刚刚完成“系列&#xff08;一&#xff09;”的安装和环境配置&#xff0c;恭喜你&#xff0c;你已经迈出了从“电脑使用者”到“程序创造者”最关键的一步。很多新手会问&#xff0c;现在有那么多…...

2026年AI文字做海报工具横评:6款实测对比,设计小白也能5分钟出图

摘要 2026年&#xff0c;AI做海报已经不是新鲜事&#xff0c;但"输入文字就能出海报"和"出一张能用的海报"之间&#xff0c;差距大得离谱。 我测了6款主流的可以AI文字做海报的工具&#xff0c;有的生成速度很快但排版像模板套娃&#xff0c;有的效果惊艳…...

基于SpringBoot的电影院选座购票系统毕业设计源码

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在构建一个基于Spring Boot框架的电影院选座购票系统以解决传统影院票务管理中存在的效率低下与用户体验不足等问题。当前电影院票务系统普遍采用单体架…...

Linux屏幕取词翻译终极指南:CuteTranslation让你的跨语言阅读变得简单高效

Linux屏幕取词翻译终极指南&#xff1a;CuteTranslation让你的跨语言阅读变得简单高效 【免费下载链接】CuteTranslation Linux屏幕取词翻译软件 项目地址: https://gitcode.com/gh_mirrors/cu/CuteTranslation 你是否经常在Linux系统上阅读外文资料时遇到语言障碍&…...

保姆级教程:在Ubuntu上为Ouster激光雷达配置PTP时间同步(含linuxptp/phc2sys避坑指南)

在Ubuntu上为Ouster激光雷达实现纳秒级PTP时间同步的完整指南 当自动驾驶车辆以60公里时速行驶时&#xff0c;1毫秒的时间误差会导致1.7厘米的位置偏差——这正是我们需要为激光雷达实现纳秒级时间同步的原因。本文将手把手带您完成Ouster激光雷达在Ubuntu系统上的PTP精确时间…...

解锁Nintendo Switch游戏备份的终极指南:nxdumptool完全攻略

解锁Nintendo Switch游戏备份的终极指南&#xff1a;nxdumptool完全攻略 【免费下载链接】nxdumptool Generates XCI/NSP/HFS0/ExeFS/RomFS/Certificate/Ticket dumps from Nintendo Switch gamecards and installed SD/eMMC titles. 项目地址: https://gitcode.com/gh_mirro…...

别再只用Hydra了!这5个SSH安全加固技巧,让你的服务器告别暴力破解

5个进阶SSH安全加固策略&#xff1a;从基础防护到企业级防御 当服务器管理员清晨打开日志&#xff0c;发现数百次失败的SSH登录尝试时&#xff0c;那种被窥视的不安感会瞬间袭来。暴力破解不再是理论威胁——互联网扫描机器人每时每刻都在寻找暴露的22端口&#xff0c;而Hydra等…...