Scala—列表(可变ListBuffer、不可变List)用法详解
Scala集合概述-链接
大家可以点击上方链接,先对Scala的集合有一个整体的概念🤣🤣🤣

在 Scala 中,列表(List)分为不可变列表(List)和可变列表(ListBuffer)。
1. 不可变列表(List)
List 是 Scala 中一种不可变的链表数据结构(数据有顺序,可重复) 。一旦创建,就不能修改其内容,但可以通过操作返回新的列表。

- 创建不可变列表
// 创建一个空的 List
val emptyList: List[Int] = List()// 创建一个包含初始元素的 List
val list1: List[Int] = List(1, 2, 3, 4, 5)// 使用 :: 操作符创建 List
val list2: List[Int] = 1 :: 2 :: 3 :: 4 :: 5 :: Nil

-
添加元素:
:::在列表头部添加一个元素:+:在列表尾部添加一个元素+::在列表头部添加一个元素
val newList1 = 0 :: list // 在头部添加元素 val newList2 = list :+ 6 // 在尾部添加元素 val newList3 = 0 +: list // 在头部添加元素 -
删除元素:
tail:返回去掉头部元素的列表drop:删除前 n 个元素filter:过滤掉不符合条件的元素
val tailList = list1.tail // 去掉头部元素 val dropList = list1.drop(2) // 删除前 2 个元素 val filteredList = list1.filter(_ % 2 == 0) // 过滤掉奇数 -
访问元素:
head:返回列表的第一个元素apply:通过索引访问元素length:返回列表的长度
val headElement = list1.head // 返回第一个元素 val thirdElement = list1(2) // 通过索引访问第三个元素 val length = list1.length // 返回列表的长度 -
遍历元素:
foreach:遍历所有元素map:映射所有元素filter:过滤元素
list1.foreach(println) // 遍历并打印所有元素val squaredList = list1.map(x => x * x) // 映射所有元素 println(squaredList.mkString(", ")) // 输出: 1, 4, 9, 16, 25val evenNumbers = list1.filter(_ % 2 == 0) // 过滤偶数 println(evenNumbers.mkString(", ")) // 输出: 2, 4
-
合并列表
++:合并两个列表
val list1 = List(1, 2, 3) val list2 = List(4, 5, 6) val combinedList = list1 ++ list2 // 结果: List(1, 2, 3, 4, 5, 6) -
反转列表
reverse:反转列表
val reversedList = list1.reverse // 结果: List(3, 2, 1) -
排序
sorted:按自然顺序排序sortWith:使用自定义比较器排序
val sortedList = list1.sorted // 结果: List(1, 2, 3) val customSortedList = list1.sortWith(_ > _) // 结果: List(3, 2, 1) -
查找元素
contains:检查列表是否包含某个元素indexOf:查找元素的索引lastIndexOf:查找元素的最后一个索引
val contains2 = list1.contains(2) // 结果: true val index = list1.indexOf(2) // 结果: 1 val lastIndex = list1.lastIndexOf(2) // 结果: 1 -
切片操作
slice:返回列表的一部分take:返回前 n 个元素drop:删除前 n 个元素splitAt:将列表分成两部分
val sliceList = list1.slice(1, 3) // 结果: List(2, 3) val takeList = list1.take(2) // 结果: List(1, 2) val dropList = list1.drop(2) // 结果: List(3) val (left, right) = list1.splitAt(2) // 结果: (List(1, 2), List(3)) -
转换操作
mkString:将列表转换为字符串toString:返回列表的字符串表示
val stringRepresentation = list1.mkString(", ") // 结果: "1, 2, 3" val toStringRepresentation = list1.toString // 结果: "List(1, 2, 3)" -
聚合操作
foldLeft:从左到右聚合foldRight:从右到左聚合reduce:聚合所有元素
val sum = list1.foldLeft(0)(_ + _) // 结果: 6 val product = list1.foldRight(1)(_ * _) // 结果: 6 val max = list1.reduce((a, b) => if (a > b) a else b) // 结果: 3 -
分组操作
groupBy:根据某个条件分组
val grouped = list1.groupBy(_ % 2 == 0) // 结果: Map(false -> List(1, 3), true -> List(2))
2. 可变列表(ListBuffer)
ListBuffer 是 Scala 中一个可变的列表类,位于 scala.collection.mutable 包中。可以高效地添加和删除元素。

- 创建可变列表
import scala.collection.mutable.ListBuffer// 创建一个空的 ListBuffer
val buffer = ListBuffer[Int]()// 创建一个包含初始元素的 ListBuffer
val buffer2 = ListBuffer(1, 2, 3, 4, 5)

- 添加元素:
+=:在列表末尾添加一个元素++=:在列表末尾添加多个元素prepend:在列表头部添加一个或多个元素
buffer += 1 // 在末尾添加一个元素
buffer ++= List(2, 3, 4) // 在末尾添加多个元素
buffer.prepend(0) // 在头部添加一个元素
buffer.prependAll(List(-1, -2)) // 在头部添加多个元素

- 删除元素:
-=:删除一个元素--=:删除多个元素remove:删除指定位置的元素
buffer -= 1 // 删除一个元素
buffer --= List(2, 3) // 删除多个元素
buffer.remove(0) // 删除第一个元素

- 访问和修改元素:
- 索引访问:使用索引访问和修改元素
val firstElement = buffer(0) // 访问第一个元素
buffer(0) = 10 // 修改第一个元素

- 遍历元素:
foreach:遍历所有元素map:映射所有元素filter:过滤元素
buffer.foreach(println) // 遍历并打印所有元素val squaredBuffer = buffer.map(x => x * x) // 映射所有元素
println(squaredBuffer.mkString(", ")) // 输出: 100, 36, 16val evenNumbersBuffer = buffer.filter(_ % 2 == 0) // 过滤偶数
println(evenNumbersBuffer.mkString(", ")) // 输出: 36
- 转换为其他集合类型:
toList:转换为不可变的ListtoArray:转换为数组
val list = buffer.toList // 转换为不可变的 List
val array = buffer.toArray // 转换为数组

-
合并列表
++=:合并两个列表
val buffer1 = ListBuffer(1, 2, 3) val buffer2 = ListBuffer(4, 5, 6) buffer1 ++= buffer2 // 结果: ListBuffer(1, 2, 3, 4, 5, 6) -
反转列表
reverse:反转列表
val reversedBuffer = buffer1.reverse // 结果: ListBuffer(6, 5, 4, 3, 2, 1) -
排序
sorted:按自然顺序排序sortWith:使用自定义比较器排序
val sortedBuffer = buffer1.sorted // 结果: ListBuffer(1, 2, 3, 4, 5, 6) val customSortedBuffer = buffer1.sortWith(_ > _) // 结果: ListBuffer(6, 5, 4, 3, 2, 1) -
查找元素
contains:检查列表是否包含某个元素indexOf:查找元素的索引lastIndexOf:查找元素的最后一个索引
val contains2 = buffer1.contains(2) // 结果: true val index = buffer1.indexOf(2) // 结果: 1 val lastIndex = buffer1.lastIndexOf(2) // 结果: 1 -
切片操作
slice:返回列表的一部分take:返回前 n 个元素drop:删除前 n 个元素splitAt:将列表分成两部分
val sliceBuffer = buffer1.slice(1, 3) // 结果: ListBuffer(2, 3) val takeBuffer = buffer1.take(2) // 结果: ListBuffer(1, 2) val dropBuffer = buffer1.drop(2) // 结果: ListBuffer(3, 4, 5, 6) val (leftBuffer, rightBuffer) = buffer1.splitAt(2) // 结果: (ListBuffer(1, 2), ListBuffer(3, 4, 5, 6)) -
转换操作
mkString:将列表转换为字符串toString:返回列表的字符串表示
val stringRepresentation = buffer1.mkString(", ") // 结果: "1, 2, 3, 4, 5, 6" val toStringRepresentation = buffer1.toString // 结果: "ListBuffer(1, 2, 3, 4, 5, 6)" -
聚合操作
foldLeft:从左到右聚合foldRight:从右到左聚合reduce:聚合所有元素
val sum = buffer1.foldLeft(0)(_ + _) // 结果: 21 val product = buffer1.foldRight(1)(_ * _) // 结果: 720 val max = buffer1.reduce((a, b) => if (a > b) a else b) // 结果: 6 -
分组操作
groupBy:根据某个条件分组
val grouped = buffer1.groupBy(_ % 2 == 0) // 结果: Map(false -> ListBuffer(1, 3, 5), true -> ListBuffer(2, 4, 6))
相关文章:
Scala—列表(可变ListBuffer、不可变List)用法详解
Scala集合概述-链接 大家可以点击上方链接,先对Scala的集合有一个整体的概念🤣🤣🤣 在 Scala 中,列表(List)分为不可变列表(List)和可变列表(ListBuffer&…...
【论文复现】偏标记学习+图像分类
📝个人主页🌹:Eternity._ 🌹🌹期待您的关注 🌹🌹 ❀ 偏标记学习图像分类 概述算法原理核心逻辑效果演示使用方式参考文献 概述 本文复现论文 Progressive Identification of True Labels for Pa…...
C嘎嘎探索篇:栈与队列的交响:C++中的结构艺术
C嘎嘎探索篇:栈与队列的交响:C中的结构艺术 前言: 小编在之前刚完成了C中栈和队列(stack和queue)的讲解,忘记的小伙伴可以去我上一篇文章看一眼的,今天小编将会带领大家吹奏栈和队列的交响&am…...
AIGC-----AIGC在虚拟现实中的应用前景
AIGC在虚拟现实中的应用前景 引言 随着人工智能生成内容(AIGC)的快速发展,虚拟现实(VR)技术的应用也迎来了新的契机。AIGC与VR的结合为创造沉浸式体验带来了全新的可能性,这种组合不仅极大地降低了VR内容的…...
Django 路由层
1. 路由基础概念 URLconf (URL 配置):Django 的路由系统是基于 urls.py 文件定义的。路径匹配:通过模式匹配 URL,并将请求传递给对应的视图处理函数。命名路由:每个路由可以定义一个名称,用于反向解析。 2. 基本路由配…...
《硬件架构的艺术》笔记(八):消抖技术
简介 在电子设备中两个金属触点随着触点的断开闭合便产生了多个信号,这就是抖动。 消抖是用来确保每一次断开或闭合触点时只有一个信号起作用的硬件设备或软件。(就是每次断开闭合只对应一个操作)。 抖动在某些模拟和逻辑电路中可能产生问…...
Spring 与 Spring MVC 与 Spring Boot三者之间的区别与联系
一.什么是Spring?它解决了什么问题? 1.1什么是Spring? Spring,一般指代的是Spring Framework 它是一个开源的应用程序框架,提供了一个简易的开发方式,通过这种开发方式,将避免那些可能致使代码…...
【算法】连通块问题(C/C++)
目录 连通块问题 解决思路 步骤: 初始化: DFS函数: 复杂度分析 代码实现(C) 题目链接:2060. 奶牛选美 - AcWing题库 解题思路: AC代码: 题目链接:687. 扫雷 -…...
如何选择黑白相机和彩色相机
我们在选择成像解决方案时黑白相机很容易被忽略,因为许多新相机提供鲜艳的颜色,鲜明的对比度和改进的弱光性能。然而,有许多应用,选择黑白相机将是更好的选择,因为他们产生更清晰的图像,更好的分辨率&#…...
Rust 力扣 - 740. 删除并获得点数
文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 首先对于这题我们如果将所有点数装入一个切片f中,该切片f中的i号下标表示所有点数为i的点数之和 那么这题就转换成了打家劫舍这道题,也就是求选择了切片中某个下标的元素后,该…...
OpenCV从入门到精通实战(七)——探索图像处理:自定义滤波与OpenCV卷积核
本文主要介绍如何使用Python和OpenCV库通过卷积操作来应用不同的图像滤波效果。主要分为几个步骤:图像的读取与处理、自定义卷积函数的实现、不同卷积核的应用,以及结果的展示。 卷积 在图像处理中,卷积是一种重要的操作,它通过…...
Docker核心概念总结
本文只是对 Docker 的概念做了较为详细的介绍,并不涉及一些像 Docker 环境的安装以及 Docker 的一些常见操作和命令。 容器介绍 Docker 是世界领先的软件容器平台,所以想要搞懂 Docker 的概念我们必须先从容器开始说起。 什么是容器? 先来看看容器较为…...
环形缓冲区
什么是环形缓冲区 环形缓冲区,也称为循环缓冲区或环形队列,是一种特殊的FIFO(先进先出)数据结构。它使用一块固定大小的内存空间来缓存数据,并通过两个指针(读指针和写指针)来管理数据的读写。当任意一个指针到达缓冲区末尾时,会自动回绕到缓冲区开头,形成一个"环"。…...
jQuery-Word-Export 使用记录及完整修正文件下载 jquery.wordexport.js
参考资料: jQuery-Word-Export导出word_jquery.wordexport.js下载-CSDN博客 近期又需要自己做个 Html2Doc 的解决方案,因为客户又不想要 Html2pdf 的下载了,当初还给我费尽心思解决Html转pdf时中文输出的问题(html转pdf文件下载之…...
云服务器部署WebSocket项目
WebSocket是一种在单个TCP连接上进行全双工通信的协议,其设计的目的是在Web浏览器和Web服务器之间进行实时通信(实时Web) WebSocket协议的优点包括: 1. 更高效的网络利用率:与HTTP相比,WebSocket的握手只…...
C#+数据库 实现动态权限设置
将权限信息存储在数据库中,支持动态调整。根据用户所属的角色、特定的功能模块,动态加载权限” 1. 数据库设计 根据这种需求,可以通过以下表设计: 用户表 (Users):存储用户信息。角色表 (Roles):存储角色…...
(原创)Android Studio新老界面UI切换及老版本下载地址
前言 这两天下载了一个新版的Android Studio,发现整个界面都发生了很大改动: 新的界面的一些设置可参考一些博客: Android Studio新版UI常用设置 但是对于一些急着开发的小伙伴来说,没有时间去适应,那么怎么办呢&am…...
Ubuntu24虚拟机-gnome-boxes
推荐使用gnome-boxes, virtualbox构建失败,multipass需要开启防火墙 sudo apt install gnome-boxes创建完毕~...
k8s rainbond centos7/win10 -20241124
参考 https://www.rainbond.com/ 国内一站式云原生平台 对centos7环境支持不太行 [lighthouseVM-16-5-centos ~]$ curl -o install.sh https://get.rainbond.com && bash ./install.sh 2024-11-24 09:56:57 ERROR: Ops! Docker daemon is not running. Start docke…...
SpringBoot+Vue滑雪社区网站设计与实现
【1】系统介绍 研究背景 随着互联网技术的快速发展和冰雪运动的普及,滑雪作为一种受欢迎的冬季运动项目,吸引了越来越多的爱好者。与此同时,社交媒体和在线社区平台的兴起为滑雪爱好者提供了一个交流经验、分享心得、获取信息的重要渠道。滑…...
Vue记事本应用实现教程
文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展:显示创建时间8. 功能扩展:记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...
【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器
一.自适应梯度算法Adagrad概述 Adagrad(Adaptive Gradient Algorithm)是一种自适应学习率的优化算法,由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率,适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...
练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...
解锁数据库简洁之道:FastAPI与SQLModel实战指南
在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
【Go语言基础【12】】指针:声明、取地址、解引用
文章目录 零、概述:指针 vs. 引用(类比其他语言)一、指针基础概念二、指针声明与初始化三、指针操作符1. &:取地址(拿到内存地址)2. *:解引用(拿到值) 四、空指针&am…...
【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
华为OD机试-最短木板长度-二分法(A卷,100分)
此题是一个最大化最小值的典型例题, 因为搜索范围是有界的,上界最大木板长度补充的全部木料长度,下界最小木板长度; 即left0,right10^6; 我们可以设置一个候选值x(mid),将木板的长度全部都补充到x,如果成功…...
