3Tuple 元组
使用过python的朋友肯定知道这个东西。
Scala中,元组也是不可变对象,其特点是容器内的对象可以是不同类型。
定义元组:
val pair = (99, "Luftballons")
很简单了,直接小括号,中间元素用逗号隔开就行了。
获取列表元素:
pair._1
pair._2
scala使用 点+下划线+下标 来访问元组中的元素。有两点可能比较怪:
关于应用,简单的用途比如:
-
在函数中,你希望返回2个或者两个以上的内容,怎么办?用Object的数组,封装一个Bean,现在都不用,return一个元组更加舒服。
(i, someValue)
i, someValue
-
已经有一个元组,想使用其中的数据,点+下划线太麻烦,看下面:
val name = ("alan", "wang")
val firstName, lastName = name
一句话,firstName、lastName都赋值了。
note:元组定义的那个小括号可以不加的,上面有用到的 ~
4set
不同与Array和List,Array是可变的,List是不可变的。Scala中set提供了不可变set和可变的set,如下图:
可变和不可变的对象提供相同的方法,但是处理结果却不一样,可变对象修改对象内容然后返回,不可变对象创建一个新的对象返回。scala的函数式编程风格鼓励使用不可变的数据结构,不过到底如何使用,可以看具体场景,如果你习惯了可变对象,那么可以先用可变对象,到熟悉了函数式编程那么尽量使用不可变对象。
4.1添加新元素(+)
可变和不可变的Set都提供了一个名为+的操作:
var set = Set(1, 2, 3) // 此处为 var,val不可重新赋值
set += 4 //set = set + 4
对于可变Set,+操作会将元素添加到自身;对于不可变的Set,返回一个添加了新元素的Set。
看一下可变Set:
import scala.collection.mutable.Set
val movieSet = Set("Hitch", "Poltergeist")
movieSet += "Shrek" // movieSet.+=(“Shrek”)
上面movieSet 执行+=之前和之后是一个对象。上面定义是val,因为可变对象不需要重新赋值。
4.2HashSet
Set一般可以实现大多数的操作。如上节所示:
var set = Set(1, 2, 3)
更详细的写法如下:
var set = Set.apply(1, 2, 3)
apply方法是Set trait 的伴生对象(object Set)定义的。如果想直接使用某个类,和上面一样:
import scala.collection.immutable.HashSet
val hashSet = HashSet("Tomatoes", "Chilies")
println(hashSet + "Coriander")
HashSet也有可变和不可变的实现。
4.3set的方法(可变和不可变)
4.3.1contains
是否包含元素
4.3.2apply
apply也可以用来测试是否包含元素,如下:
val fruit = Set("apple", "orange", "peach", "banana")
fruit("peach") // true
fruit("potato") // false
4.3.3subSetOf
用来检测一个Set是否是另一个的子集。
4.3.4+
增加一个或者多个元素
set + element
set + (element1, element2)
4.3.5++
Set相加。
setA + setB
4.3.6移除
和增加元素一样,移除的方法也有两个 - 和 --,用法和+ 、++相同。
如果要移除set中所有元素,那么可以用empty方法。
4.3.7&、intersection
获得两个Set的交集
setA & setB
setA intersection setB
4.3.8|、union
获得两个Set的并集
setA | setB
setA union setB
4.3.9&~ 、diff
获得两个Set中不同的部分。
SetA &~ setB
setA diff setB
4.4可变Set、mutable.Set
可变Set一般都返回元素变化后的自身。
4.4.1+=
Set + a
set + (a, b, c)
4.4.2++=
SetA ++= setB
4.4.3add
添加一个元素,如果这个元素以前不存在,那么返回true,如果之前已经存在则返回false。
4.4.4-=
4.4.5--=
4.4.6remove
类似add
4.4.7retain
4.4.8clear
删除所有的元素
4.4.9update、()=
set(x)=newX
4.4.10clone
克隆对象。
分享到:
相关推荐
#### 三、Scala数据结构和容器 - **列表(List)**:Scala中提供了多种列表的操作方法,如`::`操作符用于列表的拼接。 - **数组(Array)**:通过代码示例展示了如何在Scala中创建和初始化数组。 - **元组(Tuple)**:...
2. `src/main/scala`: 代码源文件存放目录,包含了使用Scala编写的业务逻辑和服务端点。 3. `src/main/resources`: 存放静态资源,如配置文件等。 4. `project/`: 包含了项目的sbt插件和构建设置。 **五、示例项目...
Option是Scala中的一个容器类,表示可能为空或存在的值。它有两种类型:`Some[T]`表示存在值,`None`表示没有值。Option是安全处理null的好方法,可以避免空指针异常。 在压缩包中的文档,如"1.模式的种类.md"、"3....
Scala是一种多范式编程语言,融合了面向对象和函数式编程的概念,使得代码更加简洁、优雅。在这个项目中,我们将深入探讨如何使用Scala来构建一个Slack bot,以及涉及的相关技术点。 1. **Scala基础知识** - **...
- **ActorSystem**:包含多个 Actor 的容器。 - **Message**:Actor 之间通信的基本单位。 - **Supervisor Strategy**:用于处理 Actor 故障的策略。 ##### 2.2 Actor Systems - **创建 ActorSystem**:通过 `...
Scala是一种融合了面向对象和函数式编程特性的现代编程语言。它旨在提供一种更加简洁、高效和安全的方式来构建复杂的软件系统。本教程专为已有一定编程经验、特别是熟悉Java语言的程序员设计,帮助他们快速上手Scala...
2. **Scala语言**:一种多范式的编程语言,结合了面向对象和函数式编程。它的类型系统和表达能力强大,是构建复杂Web应用的理想选择。 3. **Slick**:Slick是Apache 2.0许可下的一个现代、类型安全的数据库驱动,它...
Scala是一种多范式编程语言,它将面向对象编程和函数式编程相结合。本文档提供了一个Scala初学者指南,涵盖了Scala的核心概念和特性,帮助读者理解并掌握Scala的用法。 首先,Scala拥有强大的模式匹配功能,它能够...
2. **组件定义**: 每个需要依赖注入的类都应该声明为特质,并带有`@Singleton`注解,表示它是单例对象。例如,可以有一个`UserService`特质,然后在实现类上使用`@Inject`注解来声明依赖。 3. **控制器`: Play的...
Scala是一种多范式编程语言,它将面向对象编程和函数式编程结合起来,让开发者可以在同一个项目中,甚至在同一个代码文件中使用这两种范式。Scala语言的设计注重简洁性和表达力,同时也提供了强大的类型系统和抽象...
- **Scala**是一种多范式编程语言,它融合了面向对象编程和函数式编程的特点。Scala语言的设计旨在提高代码的可读性和表达能力,同时保持高性能。 - Scala运行在Java平台上,并且与Java语言完全兼容,这意味着可以...
Scala是一种多范式编程语言,它结合了面向对象和函数式编程的特点。它提供了强大的类型系统,包括类型推断、模式匹配和高阶类型。在Scala中,一切都是对象,包括函数,这使得函数可以作为其他函数的参数或返回值。 ...
JAVA 程序设计师的 SCALA 入门教学, 此教学将对 Scala 语言以及编译器做一个简易介绍。设定的读者为具有程设经验且想要看 Scala 功能概要的人。内文假设读者有着基本、特别是 Java 上的对象导向程设知识。
包是一种命名空间,用于避免命名冲突,而对象则可以看作是单例类,它们是代码的容器,可以包含方法、变量和其他对象。通过包对象,我们可以创建包级别的常量和函数,这在大型项目中特别有用,因为它们提供了一种全局...
2. **类与对象**:Scala 中的类和对象是统一的,每个类都有一个隐含的对象,称为伴生对象。同时,每个对象也可以有一个伴生类,它们之间可以相互访问私有成员。 3. **函数是一等公民**:在 Scala 中,函数可以作为...
Jetty是一个轻量级、高性能的Java web服务器和Servlet容器,而Jetty NoSQL Memcached是Jetty的一个扩展,它允许将用户会话数据存储在Memcached这种分布式内存对象缓存系统中,从而提高了会话数据的访问速度和可伸缩...
Scala是一种强大的、面向对象的编程语言,它集成了函数式编程的特点,被广泛应用于大数据处理、分布式计算和Web开发等领域。Cats是Scala生态系统中的一个核心库,专注于提供类型类和Monad等抽象,用于构建类型安全、...
2. **面向对象编程**:探讨Scala如何支持面向对象编程,包括类、对象、继承、多态等概念。 3. **函数式编程**:介绍函数式编程的核心理念,如纯函数、高阶函数、递归等,并展示了如何在Scala中实现这些概念。 4. **...
2. **函数式编程**:Scala是函数式编程的首选语言之一,它支持高阶函数、柯里化、闭包、不可变数据结构和尾递归优化等特性。这些功能使开发者能够编写出更简洁、更易于测试和并行处理的代码。 3. **Actor模型**:...
1.1.1 富有魅力的Scala 2 1.1.2 关于Java 8 3 1.2 安装Scala 3 1.2.1 使用SBT 5 1.2.2 执行Scala命令行工具 6 1.2.3 在IDE中运行Scala REPL 8 1.3 使用Scala 8 1.4 并发 17 1.5 本章回顾与...