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)") |
元组把多个值合并成单一的复合型的值。元组内的值可以是任何类型,而且可以不必是同一类型。 可以在定义元组的时候给其中的单个元素命名,在命名之后,你就可以通过访问名字来获取元素的值了 |
||
String | NSString,NSMutableString | Swift 的 String类型桥接到了基础库中的 NSString类。Foundation 同时也扩展了所有 NSString 定义的方法给 String 。也就是说,如果你导入 Foundation ,就可以在 String 中访问所有的 NSString 方法,无需转换格式。 | *** Swift 默认拷贝 *** Swift 的 String类型是一种值类型。如果你创建了一个新的 String值, String值在传递给方法或者函数的时候会被复制过去,还有赋值给常量或者变量的时候也是一样。每一次赋值和传递,现存的 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 而不仅仅是对象类型。 **
- 错误处理
//通过在函数声明过程当中加入 throws 关键字来表明这个函数会抛出一个错误
func canThrowAnError() throws {
// this function may or may not throw an error
}
//调用时
do {
try canThrowAnError()
// no error was thrown
} catch {
// an error was thrown
}
- 断言:在某些情况下,如果一些条件无法满足,你的代码很显然就不能再继续执行下去。在这种情况下,你可以通过触发你代码中的断言来结束代码的执行,以提供调试值缺失或者不可用的机会。
//你可以使用全局函数 assert(_:_:) 函数来写断言。
//向 assert(_:_:) 函数传入一个结果为 true 或者 false 的表达式以及一条会在结果为 false 的时候显式的信息:
let age = -3
assert(age >= 0, "A person's age cannot be less than zero")
//在这个栗子当中,代码执行只要在 if age >= 0 评定为 true 时才会继续,就是说,如果 age 的值非负。
//如果 age 的值是负数,在上文的代码当中, age >= 0 评定为 false ,断言就会被触发,终止应用。
- 合并空值运算符
//( 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"
- 区间运算符
- 闭区间运算符
//闭区间运算符( a...b )定义了从 a 到 b 的一组范围,并且包含 a 和 b 。 a 的值不能大于 b
for index in 1...5 {
print("\(index) times 5 is \(index * 5)")
}
- 半开区间运算符
//半开区间运算符( a..<b )定义了从 a 到 b 但不包括 b 的区间,即 半开
let names = ["Anna", "Alex", "Brian", "Jack"]
let count = names.count
for i in 0..<count {
print("Person \(i + 1) is called \(names[i])")
}