為一個(gè)已有的類绿语、結(jié)構(gòu)體行拢、枚舉類型或者協(xié)議類型添加新功能。
包括在沒有權(quán)限獲取原始源代碼的情況下擴(kuò)展類型的能力(即逆向建模)
擴(kuò)展可以為一個(gè)類型添加新的功能,但是不能重寫已有的功能驶赏。
1 擴(kuò)展的語法(Extension Syntax)
extension SomeType {
// 為 SomeType 添加的新功能寫到這里
}
// 擴(kuò)展一個(gè)已有類型,使其實(shí)現(xiàn)一些協(xié)議凡人。
extension SomeType: SomeProtocol, AnotherProctocol {
// 協(xié)議實(shí)現(xiàn)寫到這里
}
如果你通過擴(kuò)展為一個(gè)已有類型添加新功能锋谐,那么新功能對(duì)該類型的所有已有實(shí)例都是可用的,即使它們是在這個(gè)擴(kuò)展定義之前創(chuàng)建的帝际。
2 計(jì)算型屬性(Computed Properties)
extension Double {
var km: Double { return self * 1_000.0 }
var m : Double { return self }
var cm: Double { return self / 100.0 }
var mm: Double { return self / 1_000.0 }
var ft: Double { return self / 3.28084 }
}
let oneInch = 25.4.mm
擴(kuò)展可以添加新的計(jì)算型屬性蔓同,但是不可以添加存儲(chǔ)型屬性,也不可以為已有屬性添加屬性觀察器蹲诀。
3 構(gòu)造器(Initializers)
struct Size {
var width = 0.0, height = 0.0
}
struct Point {
var x = 0.0, y = 0.0
}
struct Rect {
var origin = Point()
var size = Size()
}
let defaultRect = Rect()
let memberwiseRect = Rect(origin: Point(x: 2.0, y: 2.0), size: Size(width: 5.0, height: 5.0))
extension Rect {
init(center: Point, size: Size) {
let originX = center.x - (size.width / 2)
let originY = center.y - (size.height / 2)
self.init(origin: Point(x: originX, y: originY), size: size)
}
}
let centerRect = Rect(center: Point(x: 4.0, y: 4.0), size: Size(width: 3.0, height: 3.0))
4 方法(Methods)
extension Int {
func repetitions(task: () -> Void) { // 將閉包中的任務(wù)執(zhí)行整數(shù)對(duì)應(yīng)的次數(shù)
for _ in 0..<self {
task()
}
}
}
5.repetitions(task: {
print("Hello!")
})
可變實(shí)例方法(Mutating Instance Methods)
extension Int {
mutating func square() {
self = self * self
}
}
var someInt = 3
someInt.square() // 不能直接用字面量`3.square()`
5 下標(biāo)(Subscripts)
extension Int {
subscript(digitIndex: Int) ->Int {
var decimalBase = 1
for _ in 0..<digitIndex {
decimalBase *= 10
}
return (self/decimalBase) % 10
}
}
12345678[2]
6 嵌套類型(Nested Types)
extension Int {
enum Kind {
case Negative, Zero, Positive
}
var kind: Kind {
switch self {
case 0:
return .Zero
case let x where x > 0:
return .Positive
default:
return .Negative
}
}
}
func printIntegerKinds(numbers: [Int]) {
for number in numbers {
switch number.kind {
case .Negative:
print("- ", terminator: "")
case .Zero:
print("0 ", terminator: "")
case .Positive:
print("+ ", terminator: "")
}
}
print("")
}
printIntegerKinds(numbers: [3, 19, -27, 0, -6, 0, 7])
playground文件在andyRon/LearnSwift