内建集合类型
2.3 Set
基本定义:一组无序
元素,且元素不会重复
。可以看成是只有key没有value的字典。
项目使用场景
:前几天才刚刚用字典的形式保存了用户学习课程的天数信息。现在看来,用set的形式去存储这些信息最为方便。。
集合代数:
和数学上的集合概念类似,set也有交并补的方法
并集
union()
交集
intersection()
补集
subtracting()
使用方法比较简单,这里直接把三个方法写到一起了
let numSet:Set = [1,2,3,4,5]
let otherSet:Set = [2,6]
///并集
let unionSet = numSet.union(otherSet)
print(unionSet) //[5, 6, 2, 3, 1, 4]
///交集
let intersectionSet = numSet.intersection(otherSet)
print(intersectionSet) //[2]
///补集
let subtractingSet = numSet.subtracting(otherSet)
print(subtractingSet) //[5, 3, 1, 4]
索引集合和字符集合
Foundation框架中实现了SetAlgebra协议的一共有三类:Set
IndexSet
CharacterSet
SetAlgebra
可以做什么?
提供了一些基础的数学运算:如 ==
、contains
(是否包含),交并补
、subtract
(剔除)等。
IndexSet
表示一个有正整数组成的集合,我们其实可有用Set<Int> 达到同等效果。
但IndexSet更加 高效
,内部使用了 一组范围列表
进行实现。
eg.
存储1到1000
set可能是[1,2,3,4,......,1000]
IndexSet的内部只是真正存储了1,1000 首位和末位两个数字。 它会存储```连续的范围```。So 会更加高效
CharacterSet
是一个高效存储 Unicode
的字符集合。后面讲String的时候会具体讲的~
在闭包中使用集合
我们可以利用Set去给Sequence写一个扩展,来获取序列中所有唯一元素。。具体的使用场景还没想明白。 书中写了一个例子提了下。大家如果有更好的例子欢迎补充上来~ 😜
2.4 Range
定义:两个值的区间
..<
表示不包含上边界的半开范围
...
表示包含上下边界的闭合范围
let singleNum = 0..<10//不包括10
let lowerLetters = Character("a")...Character("z")//包括z
注: 上面创建的两个都是可数范围
CountableRange。这种类型类型是可以被迭代的。
网友评论