Swift 3.1語言 Arrays、Sets和Dictionaries

//var intArray:Array = [Int]();

varintArray = [Int]();

print("count=\(intArray.count)")

intArray.append(99)

print("count=\(intArray.count)")

intArray = [];

print("count=\(intArray.count)")

letshoppingList:[String] = ["X","L"]

// shoppingList已經被構造并且擁有兩個初始項。

print("count=\(shoppingList.count)")

ifshoppingList.isEmpty{

print("Empty")

}else{

print("Not Empty")

}

foriteminshoppingList {

print(item);

}

letdic2:Dictionary= [String:String]();

print("count=\(dic2.count)")

vardic:[String:String] = ["version":"1.0.1","data":"good"];

print(dic)

dic.removeValue(forKey:"data");//想要更改就是var

print(dic);

Swift 語言提供Arrays、Sets和Dictionaries三種基本的集合類型用來存儲集合數據。數組(Arrays)是有序數據的集。集合(Sets)是無序無重復數據的集。字典(Dictionaries)是無序的鍵值對的集。

Swift 語言中的Arrays、Sets和Dictionaries中存儲的數據值類型必須明確。這意味著我們不能把不正確的數據類型插入其中。同時這也說明我們完全可以對取回值的類型非常自信。

注意:

Swift 的Arrays、Sets和Dictionaries類型被實現為泛型集合。更多關于泛型類型和集合,參見泛型章節。

集合的可變性

如果創建一個Arrays、Sets或Dictionaries并且把它分配成一個變量,這個集合將會是可變的。這意味著我們可以在創建之后添加更多或移除已存在的數據項,或者改變集合中的數據項。如果我們把Arrays、Sets或Dictionaries分配成常量,那么它就是不可變的,它的大小和內容都不能被改變。

注意:

在我們不需要改變集合的時候創建不可變集合是很好的實踐。如此 Swift 編譯器可以優化我們創建的集合。

數組(Arrays)

數組使用有序列表存儲同一類型的多個值。相同的值可以多次出現在一個數組的不同位置中。

注意: Swift 的Array類型被橋接到Foundation中的NSArray類。 更多關于在Foundation和Cocoa中使用Array的信息,參見Using Swift with Cocoa and Obejective-C一書。

數組的簡單語法

寫 Swift 數組應該遵循像Array這樣的形式,其中Element是這個數組中唯一允許存在的數據類型。我們也可以使用像[Element]這樣的簡單語法。盡管兩種形式在功能上是一樣的,但是推薦較短的那種,而且在本文中都會使用這種形式來使用數組。

創建一個空數組

我們可以使用構造語法來創建一個由特定數據類型構成的空數組:

varsomeInts = [Int]()print("someInts is of type [Int] with\(someInts.count)items.")// 打印 "someInts is of type [Int] with 0 items."

注意,通過構造函數的類型,someInts的值類型被推斷為[Int]。

或者,如果代碼上下文中已經提供了類型信息,例如一個函數參數或者一個已經定義好類型的常量或者變量,我們可以使用空數組語句創建一個空數組,它的寫法很簡單:[](一對空方括號):

someInts.append(3)// someInts 現在包含一個 Int 值someInts = []// someInts 現在是空數組,但是仍然是 [Int] 類型的。

創建一個帶有默認值的數組

Swift 中的Array類型還提供一個可以創建特定大小并且所有數據都被默認的構造方法。我們可以把準備加入新數組的數據項數量(count)和適當類型的初始值(repeatedValue)傳入數組構造函數:

varthreeDoubles = [Double](count:3, repeatedValue:0.0)// threeDoubles 是一種 [Double] 數組,等價于 [0.0, 0.0, 0.0]

通過兩個數組相加創建一個數組

我們可以使用加法操作符(+)來組合兩種已存在的相同類型數組。新數組的數據類型會被從兩個數組的數據類型中推斷出來:

varanotherThreeDoubles = [Double](count:3, repeatedValue:2.5)// anotherThreeDoubles 被推斷為 [Double],等價于 [2.5, 2.5, 2.5]varsixDoubles = threeDoubles + anotherThreeDoubles// sixDoubles 被推斷為 [Double],等價于 [0.0, 0.0, 0.0, 2.5, 2.5, 2.5]

用字面量構造數組

我們可以使用字面量來進行數組構造,這是一種用一個或者多個數值構造數組的簡單方法。字面量是一系列由逗號分割并由方括號包含的數值:

[value 1, value 2, value 3]。

下面這個例子創建了一個叫做shoppingList并且存儲String的數組:

varshoppingList: [String] = ["Eggs","Milk"]// shoppingList 已經被構造并且擁有兩個初始項。

shoppingList變量被聲明為“字符串值類型的數組“,記作[String]。 因為這個數組被規定只有String一種數據結構,所以只有String類型可以在其中被存取。 在這里,shoppinglist數組由兩個String值("Eggs"和"Milk")構造,并且由字面量定義。

注意:

Shoppinglist數組被聲明為變量(var關鍵字創建)而不是常量(let創建)是因為以后可能會有更多的數據項被插入其中。

在這個例子中,字面量僅僅包含兩個String值。匹配了該數組的變量聲明(只能包含String的數組),所以這個字面量的分配過程可以作為用兩個初始項來構造shoppinglist的一種方式。

由于 Swift 的類型推斷機制,當我們用字面量構造只擁有相同類型值數組的時候,我們不必把數組的類型定義清楚。shoppinglist的構造也可以這樣寫:

varshoppingList = ["Eggs","Milk"]

因為所有字面量中的值都是相同的類型,Swift 可以推斷出[String]是shoppinglist中變量的正確類型。

訪問和修改數組

我們可以通過數組的方法和屬性來訪問和修改數組,或者使用下標語法。

可以使用數組的只讀屬性count來獲取數組中的數據項數量:

print("The shopping list contains\(shoppingList.count)items.")// 輸出 "The shopping list contains 2 items."(這個數組有2個項)

使用布爾值屬性isEmpty作為檢查count屬性的值是否為 0 的捷徑:

ifshoppingList.isEmpty {print("The shopping list is empty.")}else{print("The shopping list is not empty.")}// 打印 "The shopping list is not empty."(shoppinglist 不是空的)

也可以使用append(_:)方法在數組后面添加新的數據項:

shoppingList.append("Flour")// shoppingList 現在有3個數據項,有人在攤煎餅

除此之外,使用加法賦值運算符(+=)也可以直接在數組后面添加一個或多個擁有相同類型的數據項:

shoppingList += ["Baking Powder"]// shoppingList 現在有四項了shoppingList += ["Chocolate Spread","Cheese","Butter"]// shoppingList 現在有七項了

可以直接使用下標語法來獲取數組中的數據項,把我們需要的數據項的索引值放在直接放在數組名稱的方括號中:

varfirstItem = shoppingList[0]// 第一項是 "Eggs"

注意:

第一項在數組中的索引值是0而不是1。 Swift 中的數組索引總是從零開始。

我們也可以用下標來改變某個已有索引值對應的數據值:

shoppingList[0] ="Six eggs"http:// 其中的第一項現在是 "Six eggs" 而不是 "Eggs"

還可以利用下標來一次改變一系列數據值,即使新數據和原有數據的數量是不一樣的。下面的例子把"Chocolate Spread","Cheese",和"Butter"替換為"Bananas"和"Apples":

shoppingList[4...6] = ["Bananas","Apples"]// shoppingList 現在有6項

注意:

不可以用下標訪問的形式去在數組尾部添加新項。

調用數組的insert(_:atIndex:)方法來在某個具體索引值之前添加數據項:

shoppingList.insert("Maple Syrup", atIndex:0)// shoppingList 現在有7項// "Maple Syrup" 現在是這個列表中的第一項

這次insert(_:atIndex:)方法調用把值為"Maple Syrup"的新數據項插入列表的最開始位置,并且使用0作為索引值。

類似的我們可以使用removeAtIndex(_:)方法來移除數組中的某一項。這個方法把數組在特定索引值中存儲的數據項移除并且返回這個被移除的數據項(我們不需要的時候就可以無視它):

letmapleSyrup = shoppingList.removeAtIndex(0)// 索引值為0的數據項被移除// shoppingList 現在只有6項,而且不包括 Maple Syrup// mapleSyrup 常量的值等于被移除數據項的值 "Maple Syrup"

注意:

如果我們試著對索引越界的數據進行檢索或者設置新值的操作,會引發一個運行期錯誤。我們可以使用索引值和數組的count屬性進行比較來在使用某個索引之前先檢驗是否有效。除了當count等于 0 時(說明這是個空數組),最大索引值一直是count - 1,因為數組都是零起索引。

數據項被移除后數組中的空出項會被自動填補,所以現在索引值為0的數據項的值再次等于"Six eggs":

firstItem = shoppingList[0]// firstItem 現在等于 "Six eggs"

如果我們只想把數組中的最后一項移除,可以使用removeLast()方法而不是removeAtIndex(_:)方法來避免我們需要獲取數組的count屬性。就像后者一樣,前者也會返回被移除的數據項:

letapples = shoppingList.removeLast()// 數組的最后一項被移除了// shoppingList 現在只有5項,不包括 Apples// apples 常量的值現在等于 "Apples" 字符串

數組的遍歷

我們可以使用for-in循環來遍歷所有數組中的數據項:

foriteminshoppingList {print(item)}// Six eggs// Milk// Flour// Baking Powder// Bananas

如果我們同時需要每個數據項的值和索引值,可以使用enumerate()方法來進行數組遍歷。enumerate()返回一個由每一個數據項索引值和數據值組成的元組。我們可以把這個元組分解成臨時常量或者變量來進行遍歷:

for(index, value)inshoppingList.enumerate() {print("Item\(String(index +1)):\(value)")}// Item 1: Six eggs// Item 2: Milk// Item 3: Flour// Item 4: Baking Powder// Item 5: Bananas

更多關于for-in循環的介紹請參見for 循環

集合(Sets)

集合(Set)用來存儲相同類型并且沒有確定順序的值。當集合元素順序不重要時或者希望確保每個元素只出現一次時可以使用集合而不是數組。

注意:

Swift的Set類型被橋接到Foundation中的NSSet類。

關于使用Foundation和Cocoa中Set的知識,請看Using Swift with Cocoa and Objective-C

集合類型的哈希值

一個類型為了存儲在集合中,該類型必須是可哈希化的--也就是說,該類型必須提供一個方法來計算它的哈希值。一個哈希值是Int類型的,相等的對象哈希值必須相同,比如a==b,因此必須a.hashValue == b.hashValue。

Swift 的所有基本類型(比如String,Int,Double和Bool)默認都是可哈希化的,可以作為集合的值的類型或者字典的鍵的類型。沒有關聯值的枚舉成員值(在枚舉有講述)默認也是可哈希化的。

注意:

你可以使用你自定義的類型作為集合的值的類型或者是字典的鍵的類型,但你需要使你的自定義類型符合 Swift 標準庫中的Hashable協議。符合Hashable協議的類型需要提供一個類型為Int的可讀屬性hashValue。由類型的hashValue屬性返回的值不需要在同一程序的不同執行周期或者不同程序之間保持相同。

因為Hashable協議符合Equatable協議,所以符合該協議的類型也必須提供一個"是否相等"運算符(==)的實現。這個Equatable協議要求任何符合==實現的實例間都是一種相等的關系。也就是說,對于a,b,c三個值來說,==的實現必須滿足下面三種情況:

a == a(自反性)

a == b意味著b == a(對稱性)

a == b && b == c意味著a == c(傳遞性)

關于符合協議的更多信息,請看協議

集合類型語法

Swift 中的Set類型被寫為Set,這里的Element表示Set中允許存儲的類型,和數組不同的是,集合沒有等價的簡化形式。

創建和構造一個空的集合

你可以通過構造器語法創建一個特定類型的空集合:

varletters =Set()print("letters is of type Setwith\(letters.count)items.")// 打印 "letters is of type Setwith 0 items."

注意:

通過構造器,這里的letters變量的類型被推斷為Set。

此外,如果上下文提供了類型信息,比如作為函數的參數或者已知類型的變量或常量,我們可以通過一個空的數組字面量創建一個空的Set:

letters.insert("a")// letters 現在含有1個 Character 類型的值letters = []// letters 現在是一個空的 Set, 但是它依然是 Set類型

用數組字面量創建集合

你可以使用數組字面量來構造集合,并且可以使用簡化形式寫一個或者多個值作為集合元素。

下面的例子創建一個稱之為favoriteGenres的集合來存儲String類型的值:

varfavoriteGenres:Set= ["Rock","Classical","Hip hop"]// favoriteGenres 被構造成含有三個初始值的集合

這個favoriteGenres變量被聲明為“一個String值的集合”,寫為Set。由于這個特定的集合含有指定String類型的值,所以它只允許存儲String類型值。這里的favoriteGenres變量有三個String類型的初始值("Rock","Classical"和"Hip hop"),并以數組字面量的方式出現。

注意:

favoriteGenres被聲明為一個變量(擁有var標示符)而不是一個常量(擁有let標示符),因為它里面的元素將會在下面的例子中被增加或者移除。

一個Set類型不能從數組字面量中被單獨推斷出來,因此Set類型必須顯式聲明。然而,由于 Swift 的類型推斷功能,如果你想使用一個數組字面量構造一個Set并且該數組字面量中的所有元素類型相同,那么你無須寫出Set的具體類型。favoriteGenres的構造形式可以采用簡化的方式代替:

varfavoriteGenres:Set= ["Rock","Classical","Hip hop"]

由于數組字面量中的所有元素類型相同,Swift 可以推斷出Set作為favoriteGenres變量的正確類型。

訪問和修改一個集合

你可以通過Set的屬性和方法來訪問和修改一個Set。

為了找出一個Set中元素的數量,可以使用其只讀屬性count:

print("I have\(favoriteGenres.count)favorite music genres.")// 打印 "I have 3 favorite music genres."

使用布爾屬性isEmpty作為一個縮寫形式去檢查count屬性是否為0:

iffavoriteGenres.isEmpty {print("As far as music goes, I'm not picky.")}else{print("I have particular music preferences.")}// 打印 "I have particular music preferences."

你可以通過調用Set的insert(_:)方法來添加一個新元素:

favoriteGenres.insert("Jazz")// favoriteGenres 現在包含4個元素

你可以通過調用Set的remove(_:)方法去刪除一個元素,如果該值是該Set的一個元素則刪除該元素并且返回被刪除的元素值,否則如果該Set不包含該值,則返回nil。另外,Set中的所有元素可以通過它的removeAll()方法刪除。

ifletremovedGenre = favoriteGenres.remove("Rock") {print("\(removedGenre)? I'm over it.")}else{print("I never much cared for that.")}// 打印 "Rock? I'm over it."

使用contains(_:)方法去檢查Set中是否包含一個特定的值:

iffavoriteGenres.contains("Funk") {print("I get up on the good foot.")}else{print("It's too funky in here.")}// 打印 "It's too funky in here."

遍歷一個集合

你可以在一個for-in循環中遍歷一個Set中的所有值。

forgenreinfavoriteGenres {print("\(genre)")}// Classical// Jazz// Hip hop

更多關于for-in循環的信息,參見For 循環

Swift 的Set類型沒有確定的順序,為了按照特定順序來遍歷一個Set中的值可以使用sort()方法,它將返回一個有序數組,這個數組的元素排列順序由操作符'<'對元素進行比較的結果來確定.

forgenreinfavoriteGenres.sort() {print("\(genre)")}// prints "Classical"http:// prints "Hip hop"http:// prints "Jazz

集合操作

你可以高效地完成Set的一些基本操作,比如把兩個集合組合到一起,判斷兩個集合共有元素,或者判斷兩個集合是否全包含,部分包含或者不相交。

基本集合操作

下面的插圖描述了兩個集合-a和b-以及通過陰影部分的區域顯示集合各種操作的結果。

使用intersect(_:)方法根據兩個集合中都包含的值創建的一個新的集合。

使用exclusiveOr(_:)方法根據在一個集合中但不在兩個集合中的值創建一個新的集合。

使用union(_:)方法根據兩個集合的值創建一個新的集合。

使用subtract(_:)方法根據不在該集合中的值創建一個新的集合。

letoddDigits:Set= [1,3,5,7,9]letevenDigits:Set= [0,2,4,6,8]letsingleDigitPrimeNumbers:Set= [2,3,5,7]oddDigits.union(evenDigits).sort()// [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]oddDigits.intersect(evenDigits).sort()// []oddDigits.subtract(singleDigitPrimeNumbers).sort()// [1, 9]oddDigits.exclusiveOr(singleDigitPrimeNumbers).sort()// [1, 2, 9]

集合成員關系和相等

下面的插圖描述了三個集合-a,b和c,以及通過重疊區域表述集合間共享的元素。集合a是集合b的父集合,因為a包含了b中所有的元素,相反的,集合b是集合a的子集合,因為屬于b的元素也被a包含。集合b和集合c彼此不關聯,因為它們之間沒有共同的元素。

使用“是否相等”運算符(==)來判斷兩個集合是否包含全部相同的值。

使用isSubsetOf(_:)方法來判斷一個集合中的值是否也被包含在另外一個集合中。

使用isSupersetOf(_:)方法來判斷一個集合中包含另一個集合中所有的值。

使用isStrictSubsetOf(_:)或者isStrictSupersetOf(_:)方法來判斷一個集合是否是另外一個集合的子集合或者父集合并且兩個集合并不相等。

使用isDisjointWith(_:)方法來判斷兩個集合是否不含有相同的值(是否沒有交集)。

lethouseAnimals:Set= ["??","??"]letfarmAnimals:Set= ["??","??","??","??","??"]letcityAnimals:Set= ["??","??"]houseAnimals.isSubsetOf(farmAnimals)// truefarmAnimals.isSupersetOf(houseAnimals)// truefarmAnimals.isDisjointWith(cityAnimals)// true

字典

字典是一種存儲多個相同類型的值的容器。每個值(value)都關聯唯一的鍵(key),鍵作為字典中的這個值數據的標識符。和數組中的數據項不同,字典中的數據項并沒有具體順序。我們在需要通過標識符(鍵)訪問數據的時候使用字典,這種方法很大程度上和我們在現實世界中使用字典查字義的方法一樣。

注意:

Swift 的Dictionary類型被橋接到Foundation的NSDictionary類。

更多關于在Foundation和Cocoa中使用Dictionary類型的信息,參見Using Swift with Cocoa and Objective-C (Swift 2.1)一書。

字典類型快捷語法

Swift 的字典使用Dictionary定義,其中Key是字典中鍵的數據類型,Value是字典中對應于這些鍵所存儲值的數據類型。

注意:

一個字典的Key類型必須遵循Hashable協議,就像Set的值類型。

我們也可以用[Key: Value]這樣快捷的形式去創建一個字典類型。雖然這兩種形式功能上相同,但是后者是首選,并且這本指導書涉及到字典類型時通篇采用后者。

創建一個空字典

我們可以像數組一樣使用構造語法創建一個擁有確定類型的空字典:

varnamesOfIntegers = [Int:String]()// namesOfIntegers 是一個空的 [Int: String] 字典

這個例子創建了一個[Int: String]類型的空字典來儲存整數的英語命名。它的鍵是Int型,值是String型。

如果上下文已經提供了類型信息,我們可以使用空字典字面量來創建一個空字典,記作[:](中括號中放一個冒號):

namesOfIntegers[16] ="sixteen"http:// namesOfIntegers 現在包含一個鍵值對namesOfIntegers = [:]// namesOfIntegers 又成為了一個 [Int: String] 類型的空字典

用字典字面量創建字典

我們可以使用字典字面量來構造字典,這和我們剛才介紹過的數組字面量擁有相似語法。字典字面量是一種將一個或多個鍵值對寫作Dictionary集合的快捷途徑。

一個鍵值對是一個key和一個value的結合體。在字典字面量中,每一個鍵值對的鍵和值都由冒號分割。這些鍵值對構成一個列表,其中這些鍵值對由方括號包含、由逗號分割:

[key1: value1, key2: value2, key3: value3]

下面的例子創建了一個存儲國際機場名稱的字典。在這個字典中鍵是三個字母的國際航空運輸相關代碼,值是機場名稱:

varairports: [String:String] = ["YYZ":"Toronto Pearson","DUB":"Dublin"]

airports字典被聲明為一種[String: String]類型,這意味著這個字典的鍵和值都是String類型。

注意:

airports字典被聲明為變量(用var關鍵字)而不是常量(let關鍵字)因為后來更多的機場信息會被添加到這個示例字典中。

airports字典使用字典字面量初始化,包含兩個鍵值對。第一對的鍵是YYZ,值是Toronto Pearson。第二對的鍵是DUB,值是Dublin。

這個字典語句包含了兩個String: String類型的鍵值對。它們對應airports變量聲明的類型(一個只有String鍵和String值的字典)所以這個字典字面量的任務是構造擁有兩個初始數據項的airport字典。

和數組一樣,我們在用字典字面量構造字典時,如果它的鍵和值都有各自一致的類型,那么就不必寫出字典的類型。airports字典也可以用這種簡短方式定義:

varairports = ["YYZ":"Toronto Pearson","DUB":"Dublin"]

因為這個語句中所有的鍵和值都各自擁有相同的數據類型,Swift 可以推斷出Dictionary是airports字典的正確類型。

訪問和修改字典

我們可以通過字典的方法和屬性來訪問和修改字典,或者通過使用下標語法。

和數組一樣,我們可以通過字典的只讀屬性count來獲取某個字典的數據項數量:

print("The dictionary of airports contains\(airports.count)items.")// 打印 "The dictionary of airports contains 2 items."(這個字典有兩個數據項)

使用布爾屬性isEmpty來快捷地檢查字典的count屬性是否等于0:

ifairports.isEmpty {print("The airports dictionary is empty.")}else{print("The airports dictionary is not empty.")}// 打印 "The airports dictionary is not empty."

我們也可以在字典中使用下標語法來添加新的數據項。可以使用一個恰當類型的鍵作為下標索引,并且分配恰當類型的新值:

airports["LHR"] ="London"http:// airports 字典現在有三個數據項

我們也可以使用下標語法來改變特定鍵對應的值:

airports["LHR"] ="London Heathrow"http:// "LHR"對應的值 被改為 "London Heathrow

作為另一種下標方法,字典的updateValue(_:forKey:)方法可以設置或者更新特定鍵對應的值。就像上面所示的下標示例,updateValue(_:forKey:)方法在這個鍵不存在對應值的時候會設置新值或者在存在時更新已存在的值。和上面的下標方法不同的,updateValue(_:forKey:)這個方法返回更新值之前的原值。這樣使得我們可以檢查更新是否成功。

updateValue(_:forKey:)方法會返回對應值的類型的可選值。舉例來說:對于存儲String值的字典,這個函數會返回一個String?或者“可選String”類型的值。

如果有值存在于更新前,則這個可選值包含了舊值,否則它將會是nil。

ifletoldValue = airports.updateValue("Dublin Airport", forKey:"DUB") {print("The old value for DUB was\(oldValue).")}// 輸出 "The old value for DUB was Dublin."

我們也可以使用下標語法來在字典中檢索特定鍵對應的值。因為有可能請求的鍵沒有對應的值存在,字典的下標訪問會返回對應值的類型的可選值。如果這個字典包含請求鍵所對應的值,下標會返回一個包含這個存在值的可選值,否則將返回nil:

ifletairportName = airports["DUB"] {print("The name of the airport is\(airportName).")}else{print("That airport is not in the airports dictionary.")}// 打印 "The name of the airport is Dublin Airport."

我們還可以使用下標語法來通過給某個鍵的對應值賦值為nil來從字典里移除一個鍵值對:

airports["APL"] ="Apple Internation"http:// "Apple Internation" 不是真的 APL 機場, 刪除它airports["APL"] =nil// APL 現在被移除了

此外,removeValueForKey(_:)方法也可以用來在字典中移除鍵值對。這個方法在鍵值對存在的情況下會移除該鍵值對并且返回被移除的值或者在沒有值的情況下返回nil:

ifletremovedValue = airports.removeValueForKey("DUB") {print("The removed airport's name is\(removedValue).")}else{print("The airports dictionary does not contain a value for DUB.")}// prints "The removed airport's name is Dublin Airport."

字典遍歷

我們可以使用for-in循環來遍歷某個字典中的鍵值對。每一個字典中的數據項都以(key, value)元組形式返回,并且我們可以使用臨時常量或者變量來分解這些元組:

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

更多關于for-in循環的信息,參見For 循環

通過訪問keys或者values屬性,我們也可以遍歷字典的鍵或者值:

forairportCodeinairports.keys {print("Airport code:\(airportCode)")}// Airport code: YYZ// Airport code: LHRforairportNameinairports.values {print("Airport name:\(airportName)")}// Airport name: Toronto Pearson// Airport name: London Heathrow

如果我們只是需要使用某個字典的鍵集合或者值集合來作為某個接受Array實例的 API 的參數,可以直接使用keys或者values屬性構造一個新數組:

letairportCodes = [String](airports.keys)// airportCodes 是 ["YYZ", "LHR"]letairportNames = [String](airports.values)// airportNames 是 ["Toronto Pearson", "London Heathrow"]

Swift 的字典類型是無序集合類型。為了以特定的順序遍歷字典的鍵或值,可以對字典的keys或values屬性使用sort()方法。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,345評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,494評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,283評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,953評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,714評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,410評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,940評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,776評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,210評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,642評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,878評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,654評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內容

  • 53.計算字符 在字符串中獲取字符值的數量, 可以使用字符串字符屬性中的計數屬性: let unusualMena...
    無灃閱讀 1,117評論 0 4
  • 1 .數組 Arrays 數組使用有序列表存儲同一類型的多個值。相同的值可以多次出現在一個數組的不同位置中。這和O...
    iceMaple閱讀 470評論 0 1
  • About me: 在學習Swift之前完完全全的零基礎編程,不知道變量與常量區別的那種零基礎。 教程主要看 ht...
    lightandall閱讀 340評論 0 1
  • 對于性格,我們總是區分為內向和外向。 外向的人活潑,開朗……內向的人不怎么愛說話,就是“悶葫蘆”一個。曾經,我就是...
    沒有寫的舒閱讀 1,154評論 47 35
  • 本文純屬心情煩悶抱怨,反正水平也很低,哀怨這么重的。煩煩煩煩煩煩,抽我吧!沒錯,這么負能量的文章不該配這么清新脫俗...
    林里葉落閱讀 261評論 0 2