Swift 語(yǔ)言提供經(jīng)典的數(shù)組和字典兩種集合類型來(lái)存儲(chǔ)集合數(shù)據(jù)。數(shù)組用來(lái)按順序存儲(chǔ)相同類型的數(shù)據(jù)。字典雖然無(wú)序存儲(chǔ)相同類型數(shù)據(jù)值但是需要由獨(dú)有的標(biāo)識(shí)符引用和尋址(就是鍵值對(duì))。
Swift 語(yǔ)言里的數(shù)組和字典中存儲(chǔ)的數(shù)據(jù)值類型必須明確。 這意味著我們不能把不正確的數(shù)據(jù)類型插入其中。 同時(shí)這也說(shuō)明我們完全可以對(duì)獲取出的值類型非常自信。 Swift 對(duì)顯式類型集合的使用確保了我們的代碼對(duì)工作所需要的類型非常清楚,也讓我們?cè)陂_(kāi)發(fā)中可以早早地找到任何的類型不匹配錯(cuò)誤。
注意:
Swift 的數(shù)組結(jié)構(gòu)在被聲明成常量和變量或者被傳入函數(shù)與方法中時(shí)會(huì)相對(duì)于其他類型展現(xiàn)出不同的特性。 獲取更多信息請(qǐng)參見(jiàn)泛型章節(jié)。
數(shù)組使用有序列表存儲(chǔ)同一類型的多個(gè)值。相同的值可以多次出現(xiàn)在一個(gè)數(shù)組的不同位置中。
Swift 數(shù)組特定于它所存儲(chǔ)元素的類型。這與 Objective-C 的 NSArray 和 NSMutableArray 不同,這兩個(gè)類可以存儲(chǔ)任意類型的對(duì)象,并且不提供所返回對(duì)象的任何特別信息。在 Swift 中,數(shù)據(jù)值在被存儲(chǔ)進(jìn)入某個(gè)數(shù)組之前類型必須明確,方法是通過(guò)顯式的類型標(biāo)注或類型推斷,而且不是必須是class
類型。例如: 如果我們創(chuàng)建了一個(gè)Int
值類型的數(shù)組,我們不能往其中插入任何不是Int
類型的數(shù)據(jù)。 Swift 中的數(shù)組是類型安全的,并且它們中包含的類型必須明確。
寫 Swift 數(shù)組應(yīng)該遵循像Array<SomeType>
這樣的形式,其中SomeType
是這個(gè)數(shù)組中唯一允許存在的數(shù)據(jù)類型。 我們也可以使用像[SomeType]
這樣的簡(jiǎn)單語(yǔ)法。 盡管兩種形式在功能上是一樣的,但是推薦較短的那種,而且在本文中都會(huì)使用這種形式來(lái)使用數(shù)組。
我們可以使用字面量來(lái)進(jìn)行數(shù)組構(gòu)造,這是一種用一個(gè)或者多個(gè)數(shù)值構(gòu)造數(shù)組的簡(jiǎn)單方法。字面量是一系列由逗號(hào)分割并由方括號(hào)包含的數(shù)值。[value 1, value 2, value 3]
。
下面這個(gè)例子創(chuàng)建了一個(gè)叫做shoppingList
并且存儲(chǔ)字符串的數(shù)組:
var shoppingList: [String] = ["Eggs", "Milk"]
// shoppingList 已經(jīng)被構(gòu)造并且擁有兩個(gè)初始項(xiàng)。
shoppingList
變量被聲明為“字符串值類型的數(shù)組“,記作[String]
。 因?yàn)檫@個(gè)數(shù)組被規(guī)定只有String
一種數(shù)據(jù)結(jié)構(gòu),所以只有String
類型可以在其中被存取。 在這里,shoppinglist
數(shù)組由兩個(gè)String
值("Eggs"
和"Milk"
)構(gòu)造,并且由字面量定義。
注意:
Shoppinglist
數(shù)組被聲明為變量(var
關(guān)鍵字創(chuàng)建)而不是常量(let
創(chuàng)建)是因?yàn)橐院罂赡軙?huì)有更多的數(shù)據(jù)項(xiàng)被插入其中。
在這個(gè)例子中,字面量?jī)H僅包含兩個(gè)String
值。匹配了該數(shù)組的變量聲明(只能包含String
的數(shù)組),所以這個(gè)字面量的分配過(guò)程就是允許用兩個(gè)初始項(xiàng)來(lái)構(gòu)造shoppinglist
。
由于 Swift 的類型推斷機(jī)制,當(dāng)我們用字面量構(gòu)造只擁有相同類型值數(shù)組的時(shí)候,我們不必把數(shù)組的類型定義清楚。 shoppinglist
的構(gòu)造也可以這樣寫:
var shoppingList = ["Eggs", "Milk"]
因?yàn)樗凶置媪恐械闹刀际窍嗤念愋?,Swift 可以推斷出[String]
是shoppinglist
中變量的正確類型。
我們可以通過(guò)數(shù)組的方法和屬性來(lái)訪問(wèn)和修改數(shù)組,或者下標(biāo)語(yǔ)法。還可以使用數(shù)組的只讀屬性count
來(lái)獲取數(shù)組中的數(shù)據(jù)項(xiàng)數(shù)量。
println("The shopping list contains \(shoppingList.count) items.")
// 輸出"The shopping list contains 2 items."(這個(gè)數(shù)組有2個(gè)項(xiàng))
使用布爾項(xiàng)isEmpty
來(lái)作為檢查count
屬性的值是否為 0 的捷徑。
if shoppingList.isEmpty {
println("The shopping list is empty.")
} else {
println("The shopping list is not empty.")
}
// 打印 "The shopping list is not empty."(shoppinglist不是空的)
也可以使用append
方法在數(shù)組后面添加新的數(shù)據(jù)項(xiàng):
shoppingList.append("Flour")
// shoppingList 現(xiàn)在有3個(gè)數(shù)據(jù)項(xiàng),有人在攤煎餅
除此之外,使用加法賦值運(yùn)算符(+=
)也可以直接在數(shù)組后面添加一個(gè)或多個(gè)擁有相同類型的數(shù)據(jù)項(xiàng):
shoppingList += ["Baking Powder"]
// shoppingList 現(xiàn)在有四項(xiàng)了
shoppingList += ["Chocolate Spread","Cheese","Butter"]
// shoppingList 現(xiàn)在有七項(xiàng)了
可以直接使用下標(biāo)語(yǔ)法來(lái)獲取數(shù)組中的數(shù)據(jù)項(xiàng),把我們需要的數(shù)據(jù)項(xiàng)的索引值放在直接放在數(shù)組名稱的方括號(hào)中:
var firstItem = shoppingList[0]
// 第一項(xiàng)是 "Eggs"
注意第一項(xiàng)在數(shù)組中的索引值是0
而不是1
。 Swift 中的數(shù)組索引總是從零開(kāi)始。
我們也可以用下標(biāo)來(lái)改變某個(gè)已有索引值對(duì)應(yīng)的數(shù)據(jù)值:
shoppingList[0] = "Six eggs"
// 其中的第一項(xiàng)現(xiàn)在是 "Six eggs" 而不是 "Eggs"
還可以利用下標(biāo)來(lái)一次改變一系列數(shù)據(jù)值,即使新數(shù)據(jù)和原有數(shù)據(jù)的數(shù)量是不一樣的。下面的例子把"Chocolate Spread"
,"Cheese"
,和"Butter"
替換為"Bananas"
和 "Apples"
:
shoppingList[4...6] = ["Bananas", "Apples"]
// shoppingList 現(xiàn)在有六項(xiàng)
注意:
我們不能使用下標(biāo)語(yǔ)法在數(shù)組尾部添加新項(xiàng)。如果我們?cè)囍眠@種方法對(duì)索引越界的數(shù)據(jù)進(jìn)行檢索或者設(shè)置新值的操作,我們會(huì)引發(fā)一個(gè)運(yùn)行期錯(cuò)誤。我們可以使用索引值和數(shù)組的count
屬性進(jìn)行比較來(lái)在使用某個(gè)索引之前先檢驗(yàn)是否有效。除了當(dāng)count
等于 0 時(shí)(說(shuō)明這是個(gè)空數(shù)組),最大索引值一直是count - 1
,因?yàn)閿?shù)組都是零起索引。
調(diào)用數(shù)組的insert(atIndex:)
方法來(lái)在某個(gè)具體索引值之前添加數(shù)據(jù)項(xiàng):
shoppingList.insert("Maple Syrup", atIndex: 0)
// shoppingList 現(xiàn)在有7項(xiàng)
// "Maple Syrup" 現(xiàn)在是這個(gè)列表中的第一項(xiàng)
這次insert
函數(shù)調(diào)用把值為"Maple Syrup"
的新數(shù)據(jù)項(xiàng)插入列表的最開(kāi)始位置,并且使用0
作為索引值。
類似的我們可以使用removeAtIndex
方法來(lái)移除數(shù)組中的某一項(xiàng)。這個(gè)方法把數(shù)組在特定索引值中存儲(chǔ)的數(shù)據(jù)項(xiàng)移除并且返回這個(gè)被移除的數(shù)據(jù)項(xiàng)(我們不需要的時(shí)候就可以無(wú)視它):
let mapleSyrup = shoppingList.removeAtIndex(0)
// 索引值為0的數(shù)據(jù)項(xiàng)被移除
// shoppingList 現(xiàn)在只有6項(xiàng),而且不包括Maple Syrup
// mapleSyrup常量的值等于被移除數(shù)據(jù)項(xiàng)的值 "Maple Syrup"
數(shù)據(jù)項(xiàng)被移除后數(shù)組中的空出項(xiàng)會(huì)被自動(dòng)填補(bǔ),所以現(xiàn)在索引值為0
的數(shù)據(jù)項(xiàng)的值再次等于"Six eggs"
:
firstItem = shoppingList[0]
// firstItem 現(xiàn)在等于 "Six eggs"
如果我們只想把數(shù)組中的最后一項(xiàng)移除,可以使用removeLast
方法而不是removeAtIndex
方法來(lái)避免我們需要獲取數(shù)組的count
屬性。就像后者一樣,前者也會(huì)返回被移除的數(shù)據(jù)項(xiàng):
let apples = shoppingList.removeLast()
// 數(shù)組的最后一項(xiàng)被移除了
// shoppingList現(xiàn)在只有5項(xiàng),不包括cheese
// apples 常量的值現(xiàn)在等于"Apples" 字符串
我們可以使用for-in
循環(huán)來(lái)遍歷所有數(shù)組中的數(shù)據(jù)項(xiàng):
for item in shoppingList {
println(item)
}
// Six eggs
// Milk
// Flour
// Baking Powder
// Bananas
如果我們同時(shí)需要每個(gè)數(shù)據(jù)項(xiàng)的值和索引值,可以使用全局enumerate
函數(shù)來(lái)進(jìn)行數(shù)組遍歷。enumerate
返回一個(gè)由每一個(gè)數(shù)據(jù)項(xiàng)索引值和數(shù)據(jù)值組成的元組。我們可以把這個(gè)元組分解成臨時(shí)常量或者變量來(lái)進(jìn)行遍歷:
for (index, value) in enumerate(shoppingList) {
println("Item \(index + 1): \(value)")
}
// Item 1: Six eggs
// Item 2: Milk
// Item 3: Flour
// Item 4: Baking Powder
// Item 5: Bananas
更多關(guān)于for-in
循環(huán)的介紹請(qǐng)參見(jiàn)for 循環(huán)。
我們可以使用構(gòu)造語(yǔ)法來(lái)創(chuàng)建一個(gè)由特定數(shù)據(jù)類型構(gòu)成的空數(shù)組:
var someInts = [Int]()
println("someInts is of type [Int] with \(someInts.count) items。")
// 打印 "someInts is of type [Int] with 0 items。"(someInts是0數(shù)據(jù)項(xiàng)的Int[]數(shù)組)
注意someInts
被設(shè)置為一個(gè)[Int]
構(gòu)造函數(shù)的輸出所以它的變量類型被定義為[Int]
。
除此之外,如果代碼上下文中提供了類型信息, 例如一個(gè)函數(shù)參數(shù)或者一個(gè)已經(jīng)定義好類型的常量或者變量,我們可以使用空數(shù)組語(yǔ)句創(chuàng)建一個(gè)空數(shù)組,它的寫法很簡(jiǎn)單:[]
(一對(duì)空方括號(hào)):
someInts.append(3)
// someInts 現(xiàn)在包含一個(gè)INT值
someInts = []
// someInts 現(xiàn)在是空數(shù)組,但是仍然是[Int]類型的。
Swift 中的Array
類型還提供一個(gè)可以創(chuàng)建特定大小并且所有數(shù)據(jù)都被默認(rèn)的構(gòu)造方法。我們可以把準(zhǔn)備加入新數(shù)組的數(shù)據(jù)項(xiàng)數(shù)量(count
)和適當(dāng)類型的初始值(repeatedValue
)傳入數(shù)組構(gòu)造函數(shù):
var threeDoubles = [Double](count: 3, repeatedValue:0.0)
// threeDoubles 是一種 [Double]數(shù)組, 等于 [0.0, 0.0, 0.0]
因?yàn)轭愋屯茢嗟拇嬖冢覀兪褂眠@種構(gòu)造方法的時(shí)候不需要特別指定數(shù)組中存儲(chǔ)的數(shù)據(jù)類型,因?yàn)轭愋涂梢詮哪J(rèn)值推斷出來(lái):
var anotherThreeDoubles = Array(count: 3, repeatedValue: 2.5)
// anotherThreeDoubles is inferred as [Double], and equals [2.5, 2.5, 2.5]
最后,我們可以使用加法操作符(+
)來(lái)組合兩種已存在的相同類型數(shù)組。新數(shù)組的數(shù)據(jù)類型會(huì)被從兩個(gè)數(shù)組的數(shù)據(jù)類型中推斷出來(lái):
var sixDoubles = threeDoubles + anotherThreeDoubles
// sixDoubles 被推斷為 [Double], 等于 [0.0, 0.0, 0.0, 2.5, 2.5, 2.5]
字典是一種存儲(chǔ)多個(gè)相同類型的值的容器。每個(gè)值(value)都關(guān)聯(lián)唯一的鍵(key),鍵作為字典中的這個(gè)值數(shù)據(jù)的標(biāo)識(shí)符。和數(shù)組中的數(shù)據(jù)項(xiàng)不同,字典中的數(shù)據(jù)項(xiàng)并沒(méi)有具體順序。我們?cè)谛枰ㄟ^(guò)標(biāo)識(shí)符(鍵)訪問(wèn)數(shù)據(jù)的時(shí)候使用字典,這種方法很大程度上和我們?cè)诂F(xiàn)實(shí)世界中使用字典查字義的方法一樣。
Swift 的字典使用時(shí)需要具體規(guī)定可以存儲(chǔ)鍵和值類型。不同于 Objective-C 的NSDictionary
和NSMutableDictionary
類可以使用任何類型的對(duì)象來(lái)作鍵和值并且不提供任何關(guān)于這些對(duì)象的本質(zhì)信息。在 Swift 中,在某個(gè)特定字典中可以存儲(chǔ)的鍵和值必須提前定義清楚,方法是通過(guò)顯性類型標(biāo)注或者類型推斷。
Swift 的字典使用Dictionary<KeyType, ValueType>
定義,其中KeyType
是字典中鍵的數(shù)據(jù)類型,ValueType
是字典中對(duì)應(yīng)于這些鍵所存儲(chǔ)值的數(shù)據(jù)類型。
KeyType
的唯一限制就是可哈希的,這樣可以保證它是獨(dú)一無(wú)二的,所有的 Swift 基本類型(例如String
,Int
, Double
和Bool
)都是默認(rèn)可哈希的,并且所有這些類型都可以在字典中當(dāng)做鍵使用。未關(guān)聯(lián)值的枚舉成員(參見(jiàn)枚舉)也是默認(rèn)可哈希的。
我們可以使用字典字面量來(lái)構(gòu)造字典,它們和我們剛才介紹過(guò)的數(shù)組字面量擁有相似語(yǔ)法。一個(gè)字典字面量是一個(gè)定義擁有一個(gè)或者多個(gè)鍵值對(duì)的字典集合的簡(jiǎn)單語(yǔ)句。
一個(gè)鍵值對(duì)是一個(gè)key
和一個(gè)value
的結(jié)合體。在字典字面量中,每一個(gè)鍵值對(duì)的鍵和值都由冒號(hào)分割。這些鍵值對(duì)構(gòu)成一個(gè)列表,其中這些鍵值對(duì)由方括號(hào)包含并且由逗號(hào)分割:
[key 1: value 1, key 2: value 2, key 3: value 3]
下面的例子創(chuàng)建了一個(gè)存儲(chǔ)國(guó)際機(jī)場(chǎng)名稱的字典。在這個(gè)字典中鍵是三個(gè)字母的國(guó)際航空運(yùn)輸相關(guān)代碼,值是機(jī)場(chǎng)名稱:
var airports: [String:String] = ["TYO": "Tokyo", "DUB": "Dublin"]
airports
字典被定義為一種 [String: String]
,它意味著這個(gè)字典的鍵和值都是String
類型。
注意:
airports
字典被聲明為變量(用var
關(guān)鍵字)而不是常量(let
關(guān)鍵字)因?yàn)楹髞?lái)更多的機(jī)場(chǎng)信息會(huì)被添加到這個(gè)示例字典中。
airports
字典使用字典字面量初始化,包含兩個(gè)鍵值對(duì)。第一對(duì)的鍵是TYO
,值是Tokyo
。第二對(duì)的鍵是DUB
,值是Dublin
。
這個(gè)字典語(yǔ)句包含了兩個(gè)String: String
類型的鍵值對(duì)。它們對(duì)應(yīng)airports
變量聲明的類型(一個(gè)只有String
鍵和String
值的字典)所以這個(gè)字典字面量是構(gòu)造兩個(gè)初始數(shù)據(jù)項(xiàng)的airport
字典。
和數(shù)組一樣,如果我們使用字面量構(gòu)造字典就不用把類型定義清楚。airports
的也可以用這種方法簡(jiǎn)短定義:
var airports = ["TYO": "Tokyo", "DUB": "Dublin"]
因?yàn)檫@個(gè)語(yǔ)句中所有的鍵和值都分別是相同的數(shù)據(jù)類型,Swift 可以推斷出Dictionary<String, String>
是airports
字典的正確類型。
我們可以通過(guò)字典的方法和屬性來(lái)讀取和修改字典,或者使用下標(biāo)語(yǔ)法。和數(shù)組一樣,我們可以通過(guò)字典的只讀屬性count
來(lái)獲取某個(gè)字典的數(shù)據(jù)項(xiàng)數(shù)量:
println("The dictionary of airports contains \(airports.count) items.")
// 打印 "The dictionary of airports contains 2 items."(這個(gè)字典有兩個(gè)數(shù)據(jù)項(xiàng))
可以使用布爾屬性isEmpty
來(lái)快捷的檢查字典的count
屬性是否等于0。
if airports.isEmpty {
println("The airports dictionary is empty.")
} else {
println("The airports dictionary is not empty.")
}
// 打印 "The airports dictionary is not empty.(這個(gè)字典不為空)"
我們也可以在字典中使用下標(biāo)語(yǔ)法來(lái)添加新的數(shù)據(jù)項(xiàng)??梢允褂靡粋€(gè)合適類型的 key 作為下標(biāo)索引,并且分配新的合適類型的值:
airports["LHR"] = "London"
// airports 字典現(xiàn)在有三個(gè)數(shù)據(jù)項(xiàng)
我們也可以使用下標(biāo)語(yǔ)法來(lái)改變特定鍵對(duì)應(yīng)的值:
airports["LHR"] = "London Heathrow"
// "LHR"對(duì)應(yīng)的值 被改為 "London Heathrow
作為另一種下標(biāo)方法,字典的updateValue(forKey:)
方法可以設(shè)置或者更新特定鍵對(duì)應(yīng)的值。就像上面所示的示例,updateValue(forKey:)
方法在這個(gè)鍵不存在對(duì)應(yīng)值的時(shí)候設(shè)置值或者在存在時(shí)更新已存在的值。和上面的下標(biāo)方法不一樣,這個(gè)方法返回更新值之前的原值。這樣方便我們檢查更新是否成功。
updateValue(forKey:)
函數(shù)會(huì)返回包含一個(gè)字典值類型的可選值。舉例來(lái)說(shuō):對(duì)于存儲(chǔ)String
值的字典,這個(gè)函數(shù)會(huì)返回一個(gè)String?
或者“可選 String
”類型的值。如果值存在,則這個(gè)可選值值等于被替換的值,否則將會(huì)是nil
。
if let oldValue = airports.updateValue("Dublin Internation", forKey: "DUB") {
println("The old value for DUB was \(oldValue).")
}
// 輸出 "The old value for DUB was Dublin."(DUB原值是dublin)
我們也可以使用下標(biāo)語(yǔ)法來(lái)在字典中檢索特定鍵對(duì)應(yīng)的值。由于使用一個(gè)沒(méi)有值的鍵這種情況是有可能發(fā)生的,可選類型返回這個(gè)鍵存在的相關(guān)值,否則就返回nil
:
if let airportName = airports["DUB"] {
println("The name of the airport is \(airportName).")
} else {
println("That airport is not in the airports dictionary.")
}
// 打印 "The name of the airport is Dublin Internation."(機(jī)場(chǎng)的名字是都柏林國(guó)際)
我們還可以使用下標(biāo)語(yǔ)法來(lái)通過(guò)給某個(gè)鍵的對(duì)應(yīng)值賦值為nil
來(lái)從字典里移除一個(gè)鍵值對(duì):
airports["APL"] = "Apple Internation"
// "Apple Internation"不是真的 APL機(jī)場(chǎng), 刪除它
airports["APL"] = nil
// APL現(xiàn)在被移除了
另外,removeValueForKey
方法也可以用來(lái)在字典中移除鍵值對(duì)。這個(gè)方法在鍵值對(duì)存在的情況下會(huì)移除該鍵值對(duì)并且返回被移除的value或者在沒(méi)有值的情況下返回nil
:
if let removedValue = airports.removeValueForKey("DUB") {
println("The removed airport's name is \(removedValue).")
} else {
println("The airports dictionary does not contain a value for DUB.")
}
// prints "The removed airport's name is Dublin International."
我們可以使用for-in
循環(huán)來(lái)遍歷某個(gè)字典中的鍵值對(duì)。每一個(gè)字典中的數(shù)據(jù)項(xiàng)都由(key, value)
元組形式返回,并且我們可以使用臨時(shí)常量或者變量來(lái)分解這些元組:
for (airportCode, airportName) in airports {
println("\(airportCode): \(airportName)")
}
// TYO: Tokyo
// LHR: London Heathrow
for-in
循環(huán)請(qǐng)參見(jiàn)For 循環(huán)。
我們也可以通過(guò)訪問(wèn)它的keys
或者values
屬性(都是可遍歷集合)檢索一個(gè)字典的鍵或者值:
for airportCode in airports.keys {
println("Airport code: \(airportCode)")
}
// Airport code: TYO
// Airport code: LHR
for airportName in airports.values {
println("Airport name: \(airportName)")
}
// Airport name: Tokyo
// Airport name: London Heathrow
如果我們只是需要使用某個(gè)字典的鍵集合或者值集合來(lái)作為某個(gè)接受Array
實(shí)例 API 的參數(shù),可以直接使用keys
或者values
屬性直接構(gòu)造一個(gè)新數(shù)組:
let airportCodes = Array(airports.keys)
// airportCodes is ["TYO", "LHR"]
let airportNames = Array(airports.values)
// airportNames is ["Tokyo", "London Heathrow"]
注意:
Swift 的字典類型是無(wú)序集合類型。其中字典鍵,值,鍵值對(duì)在遍歷的時(shí)候會(huì)重新排列,而且其中順序是不固定的。
我們可以像數(shù)組一樣使用構(gòu)造語(yǔ)法創(chuàng)建一個(gè)空字典:
var namesOfIntegers = Dictionary<Int, String>()
// namesOfIntegers 是一個(gè)空的 Dictionary<Int, String>
這個(gè)例子創(chuàng)建了一個(gè)Int, String
類型的空字典來(lái)儲(chǔ)存英語(yǔ)對(duì)整數(shù)的命名。它的鍵是Int
型,值是String
型。
如果上下文已經(jīng)提供了信息類型,我們可以使用空字典字面量來(lái)創(chuàng)建一個(gè)空字典,記作[:]
(中括號(hào)中放一個(gè)冒號(hào)):
namesOfIntegers[16] = "sixteen"
// namesOfIntegers 現(xiàn)在包含一個(gè)鍵值對(duì)
namesOfIntegers = [:]
// namesOfIntegers 又成為了一個(gè) Int, String類型的空字典
注意:
在后臺(tái),Swift 的數(shù)組和字典都是由泛型集合來(lái)實(shí)現(xiàn)的,想了解更多泛型和集合信息請(qǐng)參見(jiàn)泛型。
數(shù)組和字典都是在單個(gè)集合中存儲(chǔ)可變值。如果我們創(chuàng)建一個(gè)數(shù)組或者字典并且把它分配成一個(gè)變量,這個(gè)集合將會(huì)是可變的。這意味著我們可以在創(chuàng)建之后添加更多或移除已存在的數(shù)據(jù)項(xiàng)來(lái)改變這個(gè)集合的大小。與此相反,如果我們把數(shù)組或字典分配成常量,那么它就是不可變的,它的大小不能被改變。
對(duì)字典來(lái)說(shuō),不可變性也意味著我們不能替換其中任何現(xiàn)有鍵所對(duì)應(yīng)的值。不可變字典的內(nèi)容在被首次設(shè)定之后不能更改。不可變性對(duì)數(shù)組來(lái)說(shuō)有一點(diǎn)不同,當(dāng)然我們不能試著改變?nèi)魏尾豢勺償?shù)組的大小,但是我們可以重新設(shè)定相對(duì)現(xiàn)存索引所對(duì)應(yīng)的值。這使得 Swift 數(shù)組在大小被固定的時(shí)候依然可以做的很棒。
Swift 數(shù)組的可變性行為同時(shí)影響了數(shù)組實(shí)例如何被分配和修改,想獲取更多信息,請(qǐng)參見(jiàn)集合在賦值和復(fù)制中的行為。
注意:
在我們不需要改變數(shù)組大小的時(shí)候創(chuàng)建不可變數(shù)組是很好的習(xí)慣。如此 Swift 編譯器可以優(yōu)化我們創(chuàng)建的集合。
更多建議: