前言

  • Set:集合

    	public struct Set<Element : Hashable> : Hashable, CollectionType, ArrayLiteralConvertible
    public class NSSet : NSObject, NSCopying, NSMutableCopying, NSSecureCoding, NSFastEnumeration
    • 集 NSSet 是一个无序对象的集合。集也有动态和静态之分,NSSet 是静态类型,成员不能被修改。NSMutableSet 是动态类型,成员可以被修改。

    • 集和数组不一样的是,它存储的每一个元素都是唯一的,没有完全相同的两个元素。所以数组中如果有两个相同的值,转换为集后只会有一个值。

  • NSCountedSet:计数集合

    	public class NSCountedSet : NSMutableSet
    • NSCountedSet 这种集合中同一对象可以出现多次,然而并非在集合中存放多次这个对象,而是维护一个次数计数。当第一次将对象添加到集合中时,对象的 count 值被置为 1,然后每次将这个对象添加到集合中,count 值就会增加 1,每次从集合中删除对象,count 值就会减 1.当对象的 count 值为零时,实际上对象本身就被删除了。
  • NSIndexSet:索引集合

    	public class NSIndexSet : NSObject, NSCopying, NSMutableCopying, NSSecureCoding
    public class NSMutableIndexSet : NSIndexSet
    • NSIndexSet 这种集合用于存储有序的索引到某种数据结构,比如数组。

1、集合的 创建

	// Set 型集合

		// 不赋初值,指定数据类型为 String 型
let set1 = Set<String>() // 不指定数据类型,自动推断
let set2:Set = [1, 3, 5, 7] // 指定数据类型为 Int 型
let set3:Set<Int> = [1, 3, 5, 7] // NSSet 型集合 let swiftArr:Array = ["a", "b", "c"]
let swiftSet:Set = [1, 2, 3, 4] // 创建一个空集合
let nsSet1:NSSet = NSSet() // 指定多个元素值
let nsSet2:NSSet = [2, 4, 6, 8] // 由 Array 型数组创建
let nsSet3:NSSet = NSSet(array:swiftArr) // 由 Set 型集合创建
let nsSet4:NSSet = NSSet(set: swiftSet) // 由 NSSet 型集合创建
let nsSet5:NSSet = NSSet(set: nsSet3) // 指定一个元素值
let nsSet6:NSSet = NSSet(object: 7) // 指定多个元素值
let nsSet7:NSSet = NSSet(objects: 2, 4, 6, 8)

2、集合成员 个数的计算

	// Set 或 NSSet 型集合

		let set:NSSet = [1, 3, 5, 7]

		let num:Int = set.count

3、集合元素的获取

	// NSSet 型集合

		let nsSet:NSSet = [2, 4, 6, 8]

		// 获取集合中指定的元素,不存在时返回 nil
let object1:AnyObject? = nsSet.member(8) // 获取集合中随机的一个值,集合为空时返回 nil
let objects1:AnyObject? = nsSet.anyObject() // 获取集合中所有的元素
let objects2:AnyObject = nsSet.allObjects

4、集合的比较

	// Set 型集合

		let swiftSet1:Set = [1, 3, 5, 7]
let swiftSet2:Set = [5, 7, 9, 11] // 判断集合是否为空
let bl1:Bool = swiftSet1.isEmpty // 判断集合中是否包含某个元素
let bl2:Bool = swiftSet1.contains(7) // 相等,判断两个集合是否相等
let bl3:Bool = swiftSet1 == swiftSet2 // 子集,判断当前集合是否是指定集合的子集
let bl4:Bool = swiftSet1.isSubsetOf(swiftSet2) // 交集,返回当前集合与指定集合的交集,没有交集时返回一个空集合
let interSet:Set = swiftSet1.intersect(swiftSet2) // 并集,返回当前集合与指定集合的并集
let unionSet:Set = swiftSet1.union(swiftSet2) // NSSet 型集合 let nsSet1:NSSet = [2, 4, 6, 8]
let nsSet2:NSSet = [6, 8, 10, 12]
let nsSet3:NSMutableSet = [6, 8, 10, 12] // 判断集合中是否包含某个元素
let bl5:Bool = nsSet1.containsObject(8) // 相等,判断两个集合是否相等
let bl6:Bool = nsSet1 == nsSet2 // 相等,判断两个集合是否相等
let bl7:Bool = nsSet1.isEqualToSet(nsSet2 as Set) // 子集,判断当前集合是否是指定集合的子集
let bl8:Bool = nsSet1.isSubsetOfSet(nsSet2 as Set) // 交集,判断当前集合与指定集合是否有交集
let bl9:Bool = nsSet1.intersectsSet(nsSet2 as Set) // 交集,返回当前集合与指定集合的交集,返回到当前集合中
nsSet3.intersectSet(nsSet1 as Set) // 并集,返回当前集合与指定集合的并集,返回到当前集合中
nsSet3.unionSet(nsSet1 as Set) // 补集,返回当前集合与指定集合的补集,返回到当前集合中,当前集合中删除与指定集合的交集
nsSet3.minusSet(nsSet1 as Set)

5、集合元素的添加

	// Set 型集合

		var swiftSet:Set = [1, 3, 5, 7]

		// 向集合中添加一个元素
swiftSet.insert(8) // NSSet 型集合 let nsSet:NSMutableSet = [2, 4, 6, 8] // 向集合中添加一个元素
nsSet.addObject(10) // 向集合中添加一个数组
nsSet.addObjectsFromArray([11, 12, 12])

6、集合元素的删除

	// Set 型集合

		var swiftSet:Set = [1, 3, 5, 7]

		// 删除第一个元素
swiftSet.removeFirst() // 删除指定元素
swiftSet.remove(1) // 删除所有元素
swiftSet.removeAll(keepCapacity: true) // NSSet 型集合 let nsSet:NSMutableSet = [2, 4, 6, 8] // 删除指定元素
nsSet.removeObject(4) // 删除指定集合,当前集合中删除与指定集合的交集
nsSet.minusSet([2, 6]) // 删除所有元素
nsSet.removeAllObjects()

7、集合元素的修改

	// NSSet 型集合

		let nsSet:NSMutableSet = [2, 4, 6, 8]

		nsSet.setSet([1, 2, 3])

8、集合的遍历

	// NSSet 型集合

		let nsSet:NSSet = [2, 4, 6, 8]

		// 用闭包遍历

			nsSet.enumerateObjectsUsingBlock { (obj:AnyObject, stop:UnsafeMutablePointer<ObjCBool>) in

				print(obj)
} // 用迭代遍历 let enu:NSEnumerator = nsSet.objectEnumerator() // AnyObject 后不要加 ?,否则会导致一直循环
while let obj:AnyObject = enu.nextObject() { print(obj)
} // 条件遍历 let set:Set = nsSet.objectsPassingTest { (obj:AnyObject, stop:UnsafeMutablePointer<ObjCBool>) -> Bool in return (obj as! Int) > 5 ? true : false
} print(set)

9、计数集合的创建

	let nsCountSet1:NSCountedSet = NSCountedSet()
let nsCountSet2:NSCountedSet = NSCountedSet(capacity: 0) let nsCountSet3:NSCountedSet = NSCountedSet(array: [1, 3, 5, 7, 9]) let nsCountSet4:NSCountedSet = NSCountedSet(set: [6, 9]) let nsCountSet5:NSCountedSet = NSCountedSet(object: 8)
let nsCountSet6:NSCountedSet = NSCountedSet(objects: [2, 3, 6, 8], count: 4)

10、计数集合元素的添加

	let nsCountSet:NSCountedSet = [1, 3, 5, 7, 9]

	// 向集合中多次添加同一个元素,该元素的计数值增加
nsCountSet.addObject(6)

11、计数集合元素的删除

	let nsCountSet:NSCountedSet = [1, 3, 5, 7, 9]

	// 从集合中删除元素,该元素的计数值减小
nsCountSet.removeObject(5)

12、计数集合计数值的计算

	let nsCountedSet:NSCountedSet = NSCountedSet(array: [1, 2, 3])

	nsCountedSet.addObject(2)
nsCountedSet.removeObject(1) // 检索集合中指定元素的计数值
let num1:Int = nsCountedSet.countForObject(1) // 检索集合中指定元素的计数值
let num2:Int = nsCountedSet.countForObject(2)

13、索引集合的创建

	let indexSet1:NSIndexSet = NSIndexSet()

	let indexSet2:NSIndexSet = NSIndexSet(index: 8)

	let indexSet3:NSIndexSet = NSIndexSet(indexSet: indexSet2)

	let indexSet4:NSIndexSet = NSIndexSet(indexesInRange: NSMakeRange(1, 8))

14、索引集合元素数量的计算

	let indexSet:NSIndexSet = NSIndexSet(indexesInRange: NSMakeRange(1, 8))

	// 计算索引集合所有索引的数量
let num1:Int = indexSet.count // 计算索引集合中某一范围内的索引的数量
let num2:Int = indexSet.countOfIndexesInRange(NSMakeRange(3, 4))

15、索引集合元素的获取

	let indexSet:NSIndexSet = NSIndexSet(indexesInRange: NSMakeRange(1, 8))

	// 获取索引集合中的第一个索引,如果集合为空则返回 NSNotFound
let index1:Int = indexSet.firstIndex // 获取索引集合的最后一个索引,如果集合为空则返回 NSNotFound
let index2:Int = indexSet.lastIndex // 获取索引集合中小于指定的索引且最接近的索引,如果没有小于的索引则返回 NSNotFound
let index3:Int = indexSet.indexLessThanIndex(5) // 获取索引集合中小于等于指定的索引且最接近的索引,如果没有小于的索引则返回 NSNotFound
let index4:Int = indexSet.indexLessThanOrEqualToIndex(5) // 获取索引集合中大于指定的索引且最接近的索引,如果没有大于的索引则返回 NSNotFound
let index5:Int = indexSet.indexGreaterThanIndex(7) // 获取索引集合中大于等于指定的索引且最接近的索引,如果没有大于的索引则返回 NSNotFound
let index6:Int = indexSet.indexGreaterThanOrEqualToIndex(7)

16、索引集合的判断

	let indexSet:NSIndexSet = NSIndexSet(indexesInRange: NSMakeRange(1, 8))

	// 判断索引集合中是否包含某个索引
let bl1:Bool = indexSet.containsIndex(9) // 判断一个索引集合中是否包含另一个索引集合
let bl2:Bool = indexSet.containsIndexes(NSIndexSet(indexesInRange: NSMakeRange(2, 3))) // 判断一个索引集合中是否包含某一个范围内的所有值
let bl3:Bool = indexSet.containsIndexesInRange(NSMakeRange(2, 3)) // 判断一个索引集合中是否包含某一个范围内的值(是否有交集)
let bl4:Bool = indexSet.intersectsIndexesInRange(NSMakeRange(7, 3)) // 判断两个索引集合是否相等
let bl5:Bool = indexSet.isEqualToIndexSet(NSIndexSet(indexesInRange: NSMakeRange(1, 7)))

17、索引集合的添加

	let mIndexSet:NSMutableIndexSet = NSMutableIndexSet(indexesInRange: NSMakeRange(1, 3))

	// 添加一个索引元素,集合中已存在时会合并
mIndexSet.addIndex(6) // 添加一个索引集合,两个索引集合有交集时会合并
mIndexSet.addIndexes(NSIndexSet(indexesInRange: NSMakeRange(8, 2))) // 添加一个范围内的元素,有交集时会合并
mIndexSet.addIndexesInRange(NSMakeRange(12, 3))

18、可变索引集合删除

	let mIndexSet:NSMutableIndexSet = NSMutableIndexSet(indexesInRange: NSMakeRange(1, 10))

	// 删除一个索引集合中的索引元素
mIndexSet.removeIndex(2) // 删除指定集合中含有的索引元素
mIndexSet.removeIndexes(NSIndexSet(indexesInRange: NSMakeRange(4, 2))) // 删除指定范围内含有的索引元素
mIndexSet.removeIndexesInRange(NSMakeRange(8, 3)) // 删除全部索引元素
mIndexSet.removeAllIndexes()

19、索引集合的遍历

	let indexSet:NSIndexSet = NSIndexSet(indexesInRange: NSMakeRange(1, 5))

	// 用闭包遍历

		// 1. enumerateIndexesUsingBlock

			// 遍历获取索引集合的所有索引值
indexSet.enumerateIndexesUsingBlock { (idx:Int, stop:UnsafeMutablePointer<ObjCBool>) in print(idx)
} // 2. enumerateRangesUsingBlock // 遍历获取索引集合的起始值和索引元素数量
indexSet.enumerateRangesUsingBlock { (range:NSRange, stop:UnsafeMutablePointer<ObjCBool>) in print("\(range.location), \(range.length)")
} // 条件遍历 // 1. indexesPassingTest // 遍历索引集合,找出索引中所有满足条件的索引
let indexs:NSIndexSet = indexSet.indexesPassingTest { (idx, stop) -> Bool in return idx > 3 ? true : false
} indexs.enumerateIndexesUsingBlock { (idx:Int, stop:UnsafeMutablePointer<ObjCBool>) in print(idx)
} // 2. indexPassingTest // 遍历索引集合,找出索引中第一个满足条件的索引
let index:Int = indexs.indexPassingTest { (idx, stop) -> Bool in return idx > 3 ? true : false
} print(index)

iOS - Swift Set 集合的更多相关文章

  1. iOS Swift WisdomScanKit图片浏览器功能SDK

    iOS Swift WisdomScanKit图片浏览器功能SDK使用 一:简介      WisdomScanKit 由 Swift4.2版编写,完全兼容OC项目调用. WisdomScanKit的 ...

  2. iOS swift的xcworkspace多项目管理(架构思想)

    iOS  swift的xcworkspace多项目管理(架构思想) 技术说明: 今天在这里分享 swift下的 xcworkspace多项目管理(架构思想),能为我们在开发中带来哪些便捷?能为我们对整 ...

  3. iOS Swift 模块练习/swift基础学习

    SWIFT项目练习     SWIFT项目练习2 iOS Swift基础知识代码 推荐:Swift学习使用知识代码软件 0.swift中的宏定义(使用方法代替宏) 一.视图  +控件 1.UIImag ...

  4. ios swift 实现饼状图进度条,swift环形进度条

    ios swift 实现饼状图进度条 // // ProgressControl.swift // L02MyProgressControl // // Created by plter on 7/2 ...

  5. Building gRPC Client iOS Swift Note Taking App

    gRPC is an universal remote procedure call framework developed by Google that has been gaining inter ...

  6. iOS Swift WisdomScanKit二维码扫码SDK,自定义全屏拍照SDK,系统相册图片浏览,编辑SDK

    iOS Swift WisdomScanKit 是一款强大的集二维码扫码,自定义全屏拍照,系统相册图片编辑多选和系统相册图片浏览功能于一身的 Framework SDK [1]前言:    今天给大家 ...

  7. iOS Swift WisdomHUD 提示界面框架

    iOS Swift WisdomHUD 提示界面框架  Framework Use profile(应用简介) 一:WisdomHUD简介 今天给大家介绍一款iOS的界面显示器:WisdomHUD,W ...

  8. iOS Swift WisdomKeyboardKing 键盘智能管家SDK

    iOS Swift WisdomKeyboardKing 键盘智能管家SDK [1]前言:    今天给大家推荐个好用的开源框架:WisdomKeyboardKing,方面iOS日常开发,优点和功能请 ...

  9. iOS swift项目IM实现,从长连接到数据流解析分析之Socket

    iOS  swift项目IM实现,从长连接到底层数据解析分析之Socket 一:项目简介:  去年开始接手了一个国企移动项目,项目的需求是实现IM即时通讯功能. * 一期版本功能包括了:       ...

随机推荐

  1. Dijkstra 算法、Kruskal 算法、Prim算法、floyd算法

    1.dijkstra算法 算最短路径的,算法解决的是有向图中单个源点到其他顶点的最短路径问题. 初始化n*n的数组. 2.kruskal算法 算最小生成树的,按权值加入 3.Prim算法 类似dijk ...

  2. C# Community Projects

    Community Supported C# Drivers See the officially supported MongoDB C# driver mongodb-csharp driver ...

  3. 【Pro ASP.NET MVC 3 Framework】.学习笔记.11.ASP.NET MVC3的细节:概览MVC项目

    书Adam The Definitive Guide to HTML5 Adam Applied ASP.NET 4 in Context and Pro ASP.NET 4 到此为止,我们已经学了为 ...

  4. Windows驱动开发(中间层)

    Windows驱动开发 一.前言 依据<Windows内核安全与驱动开发>及MSDN等网络质料进行学习开发. 二.初步环境 1.下载安装WDK7.1.0(WinDDK\7600.16385 ...

  5. ACE的接受器(Acceptor)和连接器(Connector):连接建立模式

    ACE_Acceptor工厂的open()方法,或是它的缺省构造器(它实际上会调用open()方法),来开始被动侦听连接.当接受器工厂的open()方法被调用时,如果反应堆单体还没有被实例化,open ...

  6. java 23种设计模式及具体例子 收藏有时间慢慢看

    设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代 码可靠性. 毫无疑问,设计模式 ...

  7. 每日一九度之 题目1038:Sum of Factorials

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2109 解决:901 题目描述: John von Neumann, b. Dec. 28, 1903, d. Feb. 8, 1957, ...

  8. cocos2dx win打包apk

    1.配置环境(未完) 2. eclipse 导入项目之后配置 Builder新建两个.一个是ndk目录下的 ndk-build.cmd  ,一个是自己写的build_native.bat 拷贝资源的 ...

  9. 实现multbandblend

    一.首先实现 laplacian金字塔的分割和重构 #include "stdafx.h" #include <iostream> #include <vecto ...

  10. ubuntu /etc/profile和/etc/environment的比较

    先将export LANG=zh_CN加入/etc/profile ,退出系统重新登录,登录提示显示英文. 将/etc/profile 中的export LANG=zh_CN删除,将LNAG=zh_C ...