swift 類型對照
名稱 | 聲明 | 對應object-c | 使用 | 備注 | 注意 |
---|---|---|---|---|---|
Any | id | ||||
元組 | (Int, Int, Int) 或者 (String, Bool) eg:(404, "Not Found") |
let http200Status = (statusCode: 200, description: "OK") print("The status code is (http200Status.statusCode)") |
元組把多個值合并成單一的復合型的值。元組內(nèi)的值可以是任何類型,而且可以不必是同一類型。 可以在定義元組的時候給其中的單個元素命名,在命名之后,你就可以通過訪問名字來獲取元素的值了 |
||
String | NSString,NSMutableString | Swift 的 String類型橋接到了基礎庫中的 NSString類。Foundation 同時也擴展了所有 NSString 定義的方法給 String 。也就是說,如果你導入 Foundation ,就可以在 String 中訪問所有的 NSString 方法,無需轉(zhuǎn)換格式。 | *** Swift 默認拷貝 *** Swift 的 String類型是一種值類型。如果你創(chuàng)建了一個新的 String值, String值在傳遞給方法或者函數(shù)的時候會被復制過去,還有賦值給常量或者變量的時候也是一樣。每一次賦值和傳遞,現(xiàn)存的 String值都會被復制一次,傳遞走的是拷貝而不是原本。 |
swift 語法
- 可選項:
- Int?:它可能包含某些 Int 值,或者可能根本不包含值nil
- 強制展開:
print("convertedNumber has an integer value of \(convertedNumber!).")
- 可選項綁定
if let actualNumber = Int(possibleNumber) {
print("\'\(possibleNumber)\' has an integer value of \(actualNumber)")
} else {
print("\'\(possibleNumber)\' could not be converted to an integer")
}
//你可以在同一個 if 語句中包含多可選項綁定,用逗號分隔即可。
//如果任一可選綁定結果是 nil 或者布爾值為 false ,那么整個 if 判斷會被看作 false 。
//下面的兩個 if 語句是等價的:
if let firstNumber = Int("4"), let secondNumber = Int("42"), firstNumber < secondNumber && secondNumber < 100 {
print("\(firstNumber) < \(secondNumber) < 100")
}
// Prints "4 < 42 < 100"
if let firstNumber = Int("4") {
if let secondNumber = Int("42") {
if firstNumber < secondNumber && secondNumber < 100 {
print("\(firstNumber) < \(secondNumber) < 100")
}
}
}
- 隱式展開可選項
let possibleString: String? = "An optional string."
let forcedString: String = possibleString! // requires an exclamation mark
//
let assumedString: String! = "An implicitly unwrapped optional string."
let implicitString: String = assumedString // no need for an exclamation mark
- ** Swift 中的 nil 和Objective-C 中的 nil 不同,在 Objective-C 中 nil 是一個指向不存在對象的指針。在 Swift中, nil 不是指針,他是值缺失的一種特殊類型,任何類型的可選項都可以設置成 nil 而不僅僅是對象類型。 **
- 錯誤處理
//通過在函數(shù)聲明過程當中加入 throws 關鍵字來表明這個函數(shù)會拋出一個錯誤
func canThrowAnError() throws {
// this function may or may not throw an error
}
//調(diào)用時
do {
try canThrowAnError()
// no error was thrown
} catch {
// an error was thrown
}
- 斷言:在某些情況下,如果一些條件無法滿足,你的代碼很顯然就不能再繼續(xù)執(zhí)行下去。在這種情況下,你可以通過觸發(fā)你代碼中的斷言來結束代碼的執(zhí)行,以提供調(diào)試值缺失或者不可用的機會。
//你可以使用全局函數(shù) assert(_:_:) 函數(shù)來寫斷言。
//向 assert(_:_:) 函數(shù)傳入一個結果為 true 或者 false 的表達式以及一條會在結果為 false 的時候顯式的信息:
let age = -3
assert(age >= 0, "A person's age cannot be less than zero")
//在這個栗子當中,代碼執(zhí)行只要在 if age >= 0 評定為 true 時才會繼續(xù),就是說,如果 age 的值非負。
//如果 age 的值是負數(shù),在上文的代碼當中, age >= 0 評定為 false ,斷言就會被觸發(fā),終止應用。
- 合并空值運算符
//( a ?? b ):如果可選項 a 有值則展開,如果沒有值,是 nil ,則返回默認值 b 。表達式 a 必須是一個可選類型。表達式 b 必須與 a 的儲存類型相同。
//合并空值運算符是下邊代碼的縮寫:
a != nil ? a! : b
//eg:
let defaultColorName = "red"
var userDefinedColorName: String? // defaults to nil
var colorNameToUse = userDefinedColorName ?? defaultColorName
// userDefinedColorName is nil, so colorNameToUse is set to the default of "red"
- 區(qū)間運算符
- 閉區(qū)間運算符
//閉區(qū)間運算符( a...b )定義了從 a 到 b 的一組范圍,并且包含 a 和 b 。 a 的值不能大于 b
for index in 1...5 {
print("\(index) times 5 is \(index * 5)")
}
- 半開區(qū)間運算符
//半開區(qū)間運算符( a..<b )定義了從 a 到 b 但不包括 b 的區(qū)間,即 半開
let names = ["Anna", "Alex", "Brian", "Jack"]
let count = names.count
for i in 0..<count {
print("Person \(i + 1) is called \(names[i])")
}