Swift3.0集合类型(Collection Types)

Swift一样有着三种基本集合类型,数组,集合,字典。


在Swift中,这三种类型总是很明确要存储的类型,这意味着不能再插入时犯错。

集合的可变性(Mutability of Collections)

当你用"var"来创建一个数组、集合、字典的时候,它就是可变的。

数组(Arrays)

Swift的Array桥接了Foundation的NSArray类

创建一个空数组(Creating an Empty Array)
var someInts = [Int]()
print("someInts is of type [Int] with \(someInts.count) items.")
// Prints "someInts is of type [Int] with 0 items."

someInts.append(3)
// someInts now contains 1 value of type Int
someInts = []
// someInts is now an empty array, but is still of type [Int]
创建有默认值的数组(Creating an Array with a Default Value)
var threeDoubles = Array(repeating: 0.0, count: 3)
// threeDoubles is of type [Double], and equals [0.0, 0.0, 0.0]
通过两个数组连接来创建一个数组(Creating an Array by Adding Two Arrays Together)

和字符串一样,可以通过"+"直接连接,🌰:

var anotherThreeDoubles = Array(repeating: 2.5, count: 3)
// anotherThreeDoubles is of type [Double], and equals [2.5, 2.5, 2.5]

var sixDoubles = threeDoubles + anotherThreeDoubles
// sixDoubles is inferred as [Double], and equals [0.0, 0.0, 0.0, 2.5, 2.5, 2.5]
使用字面值来创建数组(Creating an Array with an Array Literal)

这个方式最简单,也最常用:

//完整写法:var shoppingList: [String] = ["Eggs", "Milk"]
var shoppingList = ["Eggs", "Milk"]
//shoppingList has been initialized with two initial items

这种情况下创建的数组,只能存储String类型,如果是别的类型会抛出错误。

接收/修改数组(Accessing and Modifying an Array)
  • 用"count"属性,读取共有多少个数值。
  • 用"isEmpty"属性,判断是否为空
  • 用"append(_:)"方法追加一个元素:
shoppingList.append("Bread")
//shoppingList now contains 3 items

也可以用"+="来追加元素

shoppingList += ["Baking Powder"]
// shoppingList now contains 4 items
shoppingList += ["Chocolate Spread", "Cheese", "Butter"]
// shoppingList now contains 7 items
  • 通过下标索引值来获取(修改)对应元素。同样可以通过下标范围来修改对应元素。
shoppingList[4...6] = ["Bananas", "Apples"]
//shoppingList now contains 6 items

注意,不能用下标来追加元素。

  • 使用"insert(_:at:)"方法来插入元素
shoppingList.insert("Maple Syrup", at: 0)
// shoppingList now contains 7 items
// "Maple Syrup" is now the first item in the list
  • 和插入类似,可以用"remove(at:)"方法来删除对应元素。想要删除最后一个元素的时候可以使用"removeLast()"方法。

当数组为空时(count = 0),数组的最大有效索引值总是count -1,因为索引值是从0开始的。

数组的遍历(Iterating Over an Array)

可以使用"for-in"循环。当需要索引值的时候,可以使用"enumerated()"方法,🌰:


🌰

index和value可以任意命名。

集合(Sets)

只能添加遵守Hashable协议的类型。

创建和初始化一个空的集合(Creating and Initializing an Empty Set)
var letters = Set<Character>()
print("letters is of type Set<Character> with \(letters.count) items")
// Prints "letters is of type Set<Character> with 0 items"

letters.insert("a")
// letters now contains 1 value of type Character
letters = []
// letters is now an empty set, but is still of type Set<Character>
用数组字面量创建一个集合(Creating a Set with an Array Literal)
// 完整写法:var favoriteGenres: Set<String> = ["Rock", "Classical", "Hip hop"]
var favoriteGenres: Set = ["Rock", "Classical", "Hip hop"]
接收/修改集合(Accessing and Modifying a Set)
  • 通过"count"属性来访问元素个数。
  • 通过"isEmpty"属性来判断元素个数是否为0。
  • 通过"insert(_:)"方法来追加新元素。
  • 通过"remove(_:)"方法来删除元素。这个方法返回删除之,如果返回为nil则说明集合中没有该数值,🌰:
if let removeGenre = favoriteGenres.remove("Rock") {
    print("\(removedGenre)? I'm over it.")
} else {
    print("I never much cared for that.")
}

// Prints "Rock? I'm over it."

  • 通过"contains(_:)"方法来判断是否包含这个元素。
集合的遍历(Iterating Over a Set)
  • 可以使用"for-in"循环进行遍历。
  • 因为Swift的Set类型是没有顺序的,可以用"sorted()"方法进行升序排序,该方法返回的是一个数组,🌰:
for genre in favoriteGenres.sorted() {
    print("\(genre)")
}
// Classical
// Hip hop
// Jazz

Performing Set Operations(不知道怎么翻译了😂)

基本的集合操作(Fundamental Set Operations)
基本的集合操作
  • 通过"intersection(_:)"方法得到两个集合的交集。(a ∩ b)
  • 通过"symmetricDifference(_:)"方法得到除去包含两个集合的值,并且除去都包含的部分。(a ∪ b - a ∩ b)
  • 通过"union(_:)"方法得到两个集合的并集。(a ∪ b)
  • 通过"subtracting(_:)"方法得到前者与后者的差集。(a - b)
let oddDigits: Set = [1, 3, 5, 7, 9]
let evenDigits: Set = [0, 2, 4, 6, 8]
let singleDigitPrimeNumbers: Set = [2, 3, 5, 7]

oddDigits.union(evenDigits).sorted()
// [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
oddDigits.intersection(evenDigits).sorted()
// []
oddDigits.subtracting(singleDigitPrimeNumbers).sorted()
// [1, 9]
oddDigits.symmetricDifference(singleDigitPrimeNumbers).sorted()
// [1, 2, 9]
集合的成员和相等(Set Membership and Equality)
  • 通过"=="判断两个集合是否包含所有相同的元素
  • 通过"isSubset(of:)"方法判断前者是否是后者的子集。
  • 通过"isSuperset(of:)"方法判断后者是否是前者的子集。
  • 通过"isStrictSubset(of:)"或者"isStrictSuperset(of:)"判断是否是真子集(为子集,且不相等)。
  • 通过"isDisjoint(with:)"方法判断两个集合是否有相同的元素,就是判断两个集合是否有交集。
let houseAnimals: Set = ["🐶", "🐱"]
let farmAnimals: Set = ["🐮", "🐔", "🐑", "🐶", "🐱"]
let cityAnimals: Set = ["🐦", "🐭"]

houseAnimals.isSubset(of: farmAnimals)
// true
farmAnimals.isSuperset(of: houseAnimals)
// true
farmAnimals.isDisjoint(with: cityAnimals)
// true

字典(Dictionaries)

key必须遵守Hashable协议。

创建空字典(Creating an Empty Dictionary)
var namesOfIntegers = [Int: String]()
// namesOfIntegers is an empty [Int: String] dictionary
namesOfIntegers[16] = "sixteen"
// namesOfIntegers now contains 1 key-value pair
namesOfIntegers = [:]
// namesOfIntegers is once again an empty dictionary of type [Int: String]
通过字面量来创建字典(Creating a Dictionary with a Dictionary Literal)
//完整写法
var airports: [String: String] = ["YYZ": "Toronto Pearson", "DUB": "Dublin"]
var airports = ["YYZ": "Toronto Pearson", "DUB": "Dublin"]
接收/修改字典(Accessing and Modifying a Dictionary)
  • 通过"count"属性来访问有多少键值对。
  • 通过"isEmpty"属性来访问是否为空。
  • 可以使用下标语法来追加、修改键值对。
airports["LHR"] = "London"
// the airports dictionary now contains 3 items

airports["LHR"] = "London Heathrow"
// the value for "LHR" has been changed to "London Heathrow"

也可以通过updateValue(_:forKey:)来完成追加、修改功能。当有该key时,返回旧值(old value);当没有该key时,返回nil,并且创建新的键值对。

  • 可以使用下标方法来删除键值对,方法是直接将key设为nil。
airports["APL"] = "Apple International"
// "Apple International" is not the real airport for APL, so delete it
airports["APL"] = nil
// APL has now been removed from the dictionary

或者使用"removeValue(forKey:)"方法来删除键值对,如果有则返回删除的值,如果没有则返回nil。

字典的遍历(Iterating Over a Dictionary)

使用"for-in"循环来遍历,返回的是(key, value)的元组,🌰:

for (airportCode, airportName) in airports {
    print("\(airportCode): \(airportName)")
}
// YYZ: Toronto Pearson
// LHR: London Heathrow

也可以通过字典的keys或者values分别遍历,🌰:

for airportCode in airports.keys {
    print("Airport code: \(airportCode)")
}
// Airport code: YYZ
// Airport code: LHR

for airportName in airports.values {
    print("Airport name: \(airportName)")
}
// Airport name: Toronto Pearson
// Airport name: London Heathrow
  • 如果你创建一个key或者value的数组,可以通过"keys"或"values"的属性:
let airportCodes = [String](airports.keys)
// airportCodes is ["YYZ", "LHR"]

let airportNames = [String](airports.values)
// airportNames is ["Toronto Pearson", "London Heathrow"]
  • Swift的字典是没有顺序的,只能通过对keys和values使用"sorted()"方法进行排序。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容