swiftLearn - one

swift 類型對照

名稱 聲明 對應(yīng)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)")
元組把多個值合并成單一的復(fù)合型的值。元組內(nèi)的值可以是任何類型,而且可以不必是同一類型。
可以在定義元組的時候給其中的單個元素命名,在命名之后,你就可以通過訪問名字來獲取元素的值了
String NSString,NSMutableString Swift 的 String類型橋接到了基礎(chǔ)庫中的 NSString類。Foundation 同時也擴(kuò)展了所有 NSString 定義的方法給 String 。也就是說,如果你導(dǎo)入 Foundation ,就可以在 String 中訪問所有的 NSString 方法,無需轉(zhuǎn)換格式。 *** Swift 默認(rèn)拷貝 ***
Swift 的 String類型是一種值類型。如果你創(chuàng)建了一個新的 String值, String值在傳遞給方法或者函數(shù)的時候會被復(fù)制過去,還有賦值給常量或者變量的時候也是一樣。每一次賦值和傳遞,現(xiàn)存的 String值都會被復(fù)制一次,傳遞走的是拷貝而不是原本。

swift 語法

  • 可選項(xiàng):
  • Int?:它可能包含某些 Int 值,或者可能根本不包含值nil
  • 強(qiáng)制展開:
print("convertedNumber has an integer value of \(convertedNumber!).")
  • 可選項(xiàng)綁定
if let actualNumber = Int(possibleNumber) {
 print("\'\(possibleNumber)\' has an integer value of \(actualNumber)")
} else {
 print("\'\(possibleNumber)\' could not be converted to an integer")
}
//你可以在同一個 if 語句中包含多可選項(xiàng)綁定,用逗號分隔即可。
//如果任一可選綁定結(jié)果是 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")
        }
    }
}
  • 隱式展開可選項(xiàng)
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 不是指針,他是值缺失的一種特殊類型,任何類型的可選項(xiàng)都可以設(shè)置成 nil 而不僅僅是對象類型。 **
  • 錯誤處理
//通過在函數(shù)聲明過程當(dāng)中加入 throws 關(guān)鍵字來表明這個函數(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ā)你代碼中的斷言來結(jié)束代碼的執(zhí)行,以提供調(diào)試值缺失或者不可用的機(jī)會。
//你可以使用全局函數(shù) assert(_:_:)  函數(shù)來寫斷言。
//向 assert(_:_:) 函數(shù)傳入一個結(jié)果為 true 或者 false 的表達(dá)式以及一條會在結(jié)果為 false 的時候顯式的信息:
let age = -3
assert(age >= 0, "A person's age cannot be less than zero")
//在這個栗子當(dāng)中,代碼執(zhí)行只要在 if age >= 0 評定為 true 時才會繼續(xù),就是說,如果 age 的值非負(fù)。
//如果 age 的值是負(fù)數(shù),在上文的代碼當(dāng)中, age >= 0 評定為 false ,斷言就會被觸發(fā),終止應(yīng)用。
  • 合并空值運(yùn)算符
//( a ?? b ):如果可選項(xiàng) a  有值則展開,如果沒有值,是 nil  ,則返回默認(rèn)值 b 。表達(dá)式 a 必須是一個可選類型。表達(dá)式 b  必須與 a  的儲存類型相同。
//合并空值運(yùn)算符是下邊代碼的縮寫:
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ū)間運(yùn)算符
  • 閉區(qū)間運(yùn)算符
//閉區(qū)間運(yùn)算符( a...b )定義了從 a  到 b  的一組范圍,并且包含 a  和 b  。 a  的值不能大于 b 
for index in 1...5 {
    print("\(index) times 5 is \(index * 5)")
}
  • 半開區(qū)間運(yùn)算符
//半開區(qū)間運(yùn)算符( 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])")
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容