- Scala Tutorial
- Scala - Home
- Scala - Overview
- Scala - Environment Setup
- Scala - Basic Syntax
- Scala - Data Types
- Scala - Variables
- Scala - Classes & Objects
- Scala - Access Modifiers
- Scala - Operators
- Scala - IF ELSE
- Scala - Loop Statements
- Scala - Functions
- Scala - Closures
- Scala - Strings
- Scala - Arrays
- Scala - Collections
- Scala - Traits
- Scala - Pattern Matching
- Scala - Regular Expressions
- Scala - Exception Handling
- Scala - Extractors
- Scala - Files I/O
- Scala Useful Resources
- Scala - Quick Guide
- Scala - Useful Resources
- Scala - Discussion
Scala - 集
Scala Set 是同一类型的成对不同元素的集合。换句话说,Set 是不包含重复元素的集合。Set 有两种,不可变的和可变的。可变对象和不可变对象之间的区别在于,当对象不可变时,对象本身不能更改。
默认情况下,Scala 使用不可变集。如果要使用可变 Set,则必须显式导入scala.collection.mutable.Set类。如果您想在同一个集合中同时使用可变集和不可变集,那么您可以继续将不可变集称为Set,但可以将可变集称为mutable.Set。
以下是声明不可变集的方法 -
句法
// Empty set of integer type var s : Set[Int] = Set() // Set of integer type var s : Set[Int] = Set(1,3,5,7) or var s = Set(1,3,5,7)
在定义空集时,类型注释是必要的,因为系统需要为变量分配具体类型。
片场基本操作
集合上的所有运算都可以用以下三种方法表示 -
先生编号 | 方法与说明 |
---|---|
1 |
头 此方法返回集合的第一个元素。 |
2 |
尾巴 此方法返回一个由除第一个元素之外的所有元素组成的集合。 |
3 |
是空的 如果集合为空,则此方法返回 true,否则返回 false。 |
尝试以下示例,显示基本操作方法的用法 -
例子
object Demo { def main(args: Array[String]) { val fruit = Set("apples", "oranges", "pears") val nums: Set[Int] = Set() println( "Head of fruit : " + fruit.head ) println( "Tail of fruit : " + fruit.tail ) println( "Check if fruit is empty : " + fruit.isEmpty ) println( "Check if nums is empty : " + nums.isEmpty ) } }
将上述程序保存在Demo.scala中。以下命令用于编译和执行该程序。
命令
\>scalac Demo.scala \>scala Demo
输出
Head of fruit : apples Tail of fruit : Set(oranges, pears) Check if fruit is empty : false Check if nums is empty : true
连接集合
您可以使用++运算符或Set.++()方法来连接两个或多个集合,但在添加集合时,它将删除重复元素。
以下是连接两个集合的示例。
例子
object Demo { def main(args: Array[String]) { val fruit1 = Set("apples", "oranges", "pears") val fruit2 = Set("mangoes", "banana") // use two or more sets with ++ as operator var fruit = fruit1 ++ fruit2 println( "fruit1 ++ fruit2 : " + fruit ) // use two sets with ++ as method fruit = fruit1.++(fruit2) println( "fruit1.++(fruit2) : " + fruit ) } }
将上述程序保存在Demo.scala中。以下命令用于编译和执行该程序。
命令
\>scalac Demo.scala \>scala Demo
输出
fruit1 ++ fruit2 : Set(banana, apples, mangoes, pears, oranges) fruit1.++(fruit2) : Set(banana, apples, mangoes, pears, oranges)
查找集合中的最大、最小元素
您可以使用Set.min方法找出最小值,使用Set.max方法找出集合中可用元素的最大值。以下是展示该程序的示例。
例子
object Demo { def main(args: Array[String]) { val num = Set(5,6,9,20,30,45) // find min and max of the elements println( "Min element in Set(5,6,9,20,30,45) : " + num.min ) println( "Max element in Set(5,6,9,20,30,45) : " + num.max ) } }
将上述程序保存在Demo.scala中。以下命令用于编译和执行该程序。
命令
\>scalac Demo.scala \>scala Demo
输出
Min element in Set(5,6,9,20,30,45) : 5 Max element in Set(5,6,9,20,30,45) : 45
寻找共同价值观插图
您可以使用Set.&方法或Set.intersect方法来找出两个集合之间的公共值。尝试以下示例来展示用法。
例子
object Demo { def main(args: Array[String]) { val num1 = Set(5,6,9,20,30,45) val num2 = Set(50,60,9,20,35,55) // find common elements between two sets println( "num1.&(num2) : " + num1.&(num2) ) println( "num1.intersect(num2) : " + num1.intersect(num2) ) } }
将上述程序保存在Demo.scala中。以下命令用于编译和执行该程序。
命令
\>scalac Demo.scala \>scala Demo
输出
num1.&(num2) : Set(20, 9) num1.intersect(num2) : Set(20, 9)
Scala 设置方法
以下是您在玩 Set 时可以使用的重要方法。有关可用方法的完整列表,请查看 Scala 官方文档。
先生编号 | 带有描述的方法 |
---|---|
1 |
def +(元素: A): 设置[A] 使用附加元素创建一个新集,除非该元素已存在。 |
2 |
def -(元素: A): 设置[A] 创建一个新集合,并从该集合中删除给定元素。 |
3 |
def contains(elem: A): 布尔值 如果 elem 包含在此集合中,则返回 true,否则返回 false。 |
4 |
def &(即: Set[A]): Set[A] 返回一个新集合,其中包含该集合和给定集合中的所有元素。 |
5 |
def &~(即: Set[A]): Set[A] 返回该集合与另一集合的差异。 |
6 |
def +(elem1: A, elem2: A, elem: A*): Set[A] 使用传递集中的附加元素创建一个新的不可变集 |
7 |
def ++(元素: A): 设置[A] 将此不可变集与另一个集合的元素连接到此不可变集。 |
8 |
def -(elem1: A, elem2: A, elem: A*): 设置[A] 返回一个新的不可变集,其中包含当前不可变集的所有元素,除了每个给定参数元素少出现一次之外。 |
9 |
def addString(b: StringBuilder): StringBuilder 将此不可变集的所有元素附加到字符串生成器。 |
10 |
def addString(b: StringBuilder, sep: String): StringBuilder 使用分隔符字符串将此不可变集的所有元素附加到字符串生成器。 |
11 |
def 应用(元素:A) 测试该集合中是否包含某个元素。 |
12 |
def count(p: (A) => 布尔值): Int 计算不可变集中满足谓词的元素数量。 |
13 |
def copyToArray(xs: Array[A], start: Int, len: Int): 单位 将此不可变集的元素复制到数组中。 |
14 |
def diff(即: Set[A]): Set[A] 计算该集合与另一集合的差异。 |
15 |
def drop(n: Int): 设置[A]] 返回除前 n 个元素之外的所有元素。 |
16 |
def dropRight(n: Int): 设置[A] 返回除最后 n 个元素之外的所有元素。 |
17 号 |
def dropWhile(p: (A) => 布尔值): Set[A] 删除满足谓词的元素的最长前缀。 |
18 |
def equals(that: Any): 布尔值 任意序列的 equals 方法。将此序列与其他对象进行比较。 |
19 |
def 存在(p: (A) => 布尔值): 布尔值 测试谓词是否适用于此不可变集合的某些元素。 |
20 |
def 过滤器(p: (A) => 布尔值): 设置[A] 返回此不可变集合中满足谓词的所有元素。 |
21 |
def find(p: (A) => 布尔值): 选项[A] 查找不可变集合中满足谓词的第一个元素(如果有)。 |
22 |
def forall(p: (A) => 布尔值): 布尔值 测试谓词是否适用于此不可变集合的所有元素。 |
23 |
def foreach(f: (A) => 单位): 单位 将函数 f 应用于此不可变集合的所有元素。 |
24 |
定义头:A 返回此不可变集合的第一个元素。 |
25 |
def 初始化:设置[A] 返回除最后一个元素之外的所有元素。 |
26 |
def intersect(即: Set[A]): Set[A] 计算该集合与另一个集合之间的交集。 |
27 |
def isEmpty: 布尔值 测试该集合是否为空。 |
28 |
def迭代器:迭代器[A] 在可迭代对象中包含的所有元素上创建一个新的迭代器。 |
29 |
最后一个:A 返回最后一个元素。 |
30 |
def map[B](f: (A) => B): immutable.Set[B] 通过将函数应用于此不可变集合的所有元素来构建新集合。 |
31 |
最大定义值:A 找到最大的元素。 |
32 |
定义最小值:A 找到最小的元素。 |
33 |
def mkString: 字符串 以字符串形式显示此不可变集合的所有元素。 |
34 |
def mkString(sep: 字符串): 字符串 使用分隔符字符串在字符串中显示此不可变集的所有元素。 |
35 |
默认产品:A 返回此不可变集合的所有元素相对于 num 中的 * 运算符的乘积。 |
36 |
默认大小:Int 返回此不可变集合中的元素数量。 |
37 |
def splitAt(n: Int): (集合[A], 集合[A]) 返回一对不可变集,由该不可变集的前 n 个元素和其他元素组成。 |
38 |
def subsetOf(that: Set[A]): 布尔值 如果该集合是该集合的子集,即该集合的每个元素也是该集合的元素,则返回 true。 |
39 |
定义总和:A 返回此不可变集合的所有元素相对于 num 中的 + 运算符的总和。 |
40 |
def tail: 设置[A] 返回一个不可变集合,由该不可变集合中除第一个元素之外的所有元素组成。 |
41 |
def take(n: Int): 设置[A] 返回前 n 个元素。 |
42 |
def takeRight(n: Int):设置[A] 返回最后 n 个元素。 |
43 |
def toArray: 数组[A] 返回一个包含此不可变集合的所有元素的数组。 |
44 |
def toBuffer[B >: A]: 缓冲区[B] 返回包含此不可变集合的所有元素的缓冲区。 |
45 |
def toList: 列表[A] 返回包含此不可变集合的所有元素的列表。 |
46 |
def toMap[T, U]: 地图[T, U] 将此不可变集转换为映射 |
47 |
def toSeq: Seq[A] 返回包含此不可变集合的所有元素的 seq。 |
48 |
def toString(): 字符串 返回对象的字符串表示形式。 |