Scala Set(集合)
Scala Set(集合)是沒有重複的對象集合,所有的元素都是唯一的。
Scala 集合分為可變的和不可變的集合。
默認情況下,Scala 使用的是不可變集合,如果你想使用可變集合,需要引用 scala.collection.mutable.Set 包。
默認引用 scala.collection.immutable.Set,不可變集合實例如下:
val set = Set(1,2,3) println(set.getClass.getName) // println(set.exists(_ % 2 == 0)) //true println(set.drop(1)) //Set(2,3)
如果需要使用可變集合需要引入 scala.collection.mutable.Set:
import scala.collection.mutable.Set // 可以在任何地方引入 可變集合 val mutableSet = Set(1,2,3) println(mutableSet.getClass.getName) // scala.collection.mutable.HashSet mutableSet.add(4) mutableSet.remove(1) mutableSet += 5 mutableSet -= 2 println(mutableSet) // Set(5, 3, 4) val another = mutableSet.toSet println(another.getClass.getName) // scala.collection.immutable.Set
注意: 雖然可變Set和不可變Set都有添加或刪除元素的操作,但是有一個非常大的差別。對不可變Set進行操作,會產生一個新的set,原來的set並沒有改變,這與List一樣。 而對可變Set進行操作,改變的是該Set本身,與ListBuffer類似。
集合基本操作
Scala集合有三個基本操作:
-
head返回集合第一個元素 -
tail返回一個集合,包含除了第一元素之外的其他元素 -
isEmpty在集合為空時返回true
對於Scala集合的任何操作都可以使用這三個基本操作來表達。實例如下:
object Test {
def main(args: Array[String]) {
val site = Set("zaixian", "Google", "Baidu")
val nums: Set[Int] = Set()
println( "第一網站是 : " + site.head )
println( "最後一個網站是 : " + site.tail )
println( "查看列表 site 是否為空 : " + site.isEmpty )
println( "查看 nums 是否為空 : " + nums.isEmpty )
}
}
執行以上代碼,輸出結果為:
$ vim Test.scala $ scala Test.scala 第一網站是 : zaixian 最後一個網站是 : Set(Google, Baidu) 查看列表 site 是否為空 : false 查看 nums 是否為空 : true
連接集合
你可以使用 ++ 運算符或 Set.++() 方法來連接兩個集合。如果元素有重複的就會移除重複的元素。實例如下:
object Test {
def main(args: Array[String]) {
val site1 = Set("zaixian", "Google", "Baidu")
val site2 = Set("Faceboook", "Taobao")
// ++ 作為運算符使用
var site = site1 ++ site2
println( "site1 ++ site2 : " + site )
// ++ 作為方法使用
site = site1.++(site2)
println( "site1.++(site2) : " + site )
}
}
執行以上代碼,輸出結果為:
$ vim Test.scala $ scala Test.scala site1 ++ site2 : Set(Faceboook, Taobao, Google, Baidu, zaixian) site1.++(site2) : Set(Faceboook, Taobao, Google, Baidu, zaixian)
查找集合中最大與最小元素
你可以使用 Set.min 方法來查找集合中的最小元素,使用 Set.max 方法查找集合中的最大元素。實例如下:
object Test {
def main(args: Array[String]) {
val num = Set(5,6,9,20,30,45)
// 查找集合中最大與最小元素
println( "Set(5,6,9,20,30,45) 集合中的最小元素是 : " + num.min )
println( "Set(5,6,9,20,30,45) 集合中的最大元素是 : " + num.max )
}
}
執行以上代碼,輸出結果為:
$ vim Test.scala $ scala Test.scala Set(5,6,9,20,30,45) 集合中的最小元素是 : 5 Set(5,6,9,20,30,45) 集合中的最大元素是 : 45
交集
你可以使用 Set.& 方法或 Set.intersect 方法來查看兩個集合的交集元素。實例如下:
object Test {
def main(args: Array[String]) {
val num1 = Set(5,6,9,20,30,45)
val num2 = Set(50,60,9,20,35,55)
// 交集
println( "num1.&(num2) : " + num1.&(num2) )
println( "num1.intersect(num2) : " + num1.intersect(num2) )
}
}執行以上代碼,輸出結果為:
$ vim Test.scala $ scala Test.scala num1.&(num2) : Set(20, 9) num1.intersect(num2) : Set(20, 9)
Scala Set 常用方法
下表列出了 Scala Set 常用的方法:
| 序號 | 方法及描述 |
|---|---|
| 1 |
def +(elem: A): Set[A] 為集合添加新元素,x並創建一個新的集合,除非元素已存在 |
| 2 |
def -(elem: A): Set[A] 移除集合中的元素,並創建一個新的集合 |
| 3 |
def contains(elem: A): Boolean 如果元素在集合中存在,返回 true,否則返回 false。 |
| 4 |
def &(that: Set[A]): Set[A] 返回兩個集合的交集 |
| 5 |
def &~(that: Set[A]): Set[A] 返回兩個集合的差集 |
| 6 |
def +(elem1: A, elem2: A, elems: A*): Set[A] 通過添加傳入指定集合的元素創建一個新的不可變集合 |
| 7 |
def ++(elems: A): Set[A] 合併兩個集合 |
| 8 |
def -(elem1: A, elem2: A, elems: A*): Set[A] 通過移除傳入指定集合的元素創建一個新的不可變集合 |
| 9 |
def addString(b: StringBuilder): StringBuilder 將不可變集合的所有元素添加到字串緩衝區 |
| 10 |
def addString(b: StringBuilder, sep: String): StringBuilder 將不可變集合的所有元素添加到字串緩衝區,並使用指定的分隔符號 |
| 11 |
def apply(elem: A) 檢測集合中是否包含指定元素 |
| 12 |
def count(p: (A) => Boolean): Int 計算滿足指定條件的集合元素個數 |
| 13 |
def copyToArray(xs: Array[A], start: Int, len: Int): Unit 複製不可變集合元素到數組 |
| 14 |
def diff(that: Set[A]): Set[A] 比較兩個集合的差集 |
| 15 |
def drop(n: Int): Set[A]] 返回丟棄前n個元素新集合 |
| 16 |
def dropRight(n: Int): Set[A] 返回丟棄最後n個元素新集合 |
| 17 |
def dropWhile(p: (A) => Boolean): Set[A] 從左向右丟棄元素,直到條件p不成立 |
| 18 |
def equals(that: Any): Boolean equals 方法可用於任意序列。用於比較系列是否相等。 |
| 19 |
def exists(p: (A) => Boolean): Boolean 判斷不可變集合中指定條件的元素是否存在。 |
| 20 |
def filter(p: (A) => Boolean): Set[A] 輸出符合指定條件的所有不可變集合元素。 |
| 21 |
def find(p: (A) => Boolean): Option[A] 查找不可變集合中滿足指定條件的第一個元素 |
| 22 |
def forall(p: (A) => Boolean): Boolean 查找指定條件是否適用於此集合的所有元素 |
| 23 |
def foreach(f: (A) => Unit): Unit 將函數應用到不可變集合的所有元素 |
| 24 |
def head: A 獲取不可變集合的第一個元素 |
| 25 |
def init: Set[A] 返回所有元素,除了最後一個 |
| 26 |
def intersect(that: Set[A]): Set[A] 計算兩個集合的交集 |
| 27 |
def isEmpty: Boolean 判斷集合是否為空 |
| 28 |
def iterator: Iterator[A] 創建一個新的迭代器來迭代元素 |
| 29 |
def last: A 返回最後一個元素 |
| 30 |
def map[B](f: (A) => B): immutable.Set[B] 通過給定的方法將所有元素重新計算 |
| 31 |
def max: A 查找最大元素 |
| 32 |
def min: A 查找最小元素 |
| 33 |
def mkString: String 集合所有元素作為字串顯示 |
| 34 |
def mkString(sep: String): String 使用分隔符號將集合所有元素作為字串顯示 |
| 35 |
def product: A 返回不可變集合中數字元素的積。 |
| 36 |
def size: Int 返回不可變集合元素的數量 |
| 37 |
def splitAt(n: Int): (Set[A], Set[A]) 把不可變集合拆分為兩個容器,第一個由前 n 個元素組成,第二個由剩下的元素組成 |
| 38 |
def subsetOf(that: Set[A]): Boolean 如果集合中含有子集返回 true,否則返回false |
| 39 |
def sum: A 返回不可變集合中所有數字元素之和 |
| 40 |
def tail: Set[A] 返回一個不可變集合中除了第一元素之外的其他元素 |
| 41 |
def take(n: Int): Set[A] 返回前 n 個元素 |
| 42 |
def takeRight(n: Int):Set[A] 返回後 n 個元素 |
| 43 |
def toArray: Array[A] 將集合轉換為數組 |
| 44 |
def toBuffer[B >: A]: Buffer[B] 返回緩衝區,包含了不可變集合的所有元素 |
| 45 |
def toList: List[A] 返回 List,包含了不可變集合的所有元素 |
| 46 |
def toMap[T, U]: Map[T, U] 返回 Map,包含了不可變集合的所有元素 |
| 47 |
def toSeq: Seq[A] 返回 Seq,包含了不可變集合的所有元素 |
| 48 |
def toString(): String 返回一個字串,以對象來表示 |
更多方法可以參考 API文檔

Scala 集合