介紹
擴展可以為類,結構體,枚舉和協議添加新的功能。包括可以對沒有源碼訪問權限的類型進行擴展。擴展和 Objective-C 分類 的概念類似。(和 Objective-C 的分類不一樣的是,Swift 擴展沒有名稱)。
在 Swift 中,擴展可以做到:
值得注意的是:擴展可以為類型添加功能,但是不可以重寫現有的功能。
擴展語法
使用關鍵字 extension 定義擴展:
extension SomeType { // new functionality to add to SomeType goes here}
擴展可以擴充現有的類型使之可以適應一個或多個協議:
extension SomeType: SomeProtocol, AnotherProtocol { // implementation of protocol requirements goes here}
計算屬性
擴展可以為現有的類型添加計算實例屬性和計算類型屬性:
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.mmprint("One inch is /(oneInch) meters")// Prints "One inch is 0.0254 meters"let threeFeet = 3.ftprint("Three feet is /(threeFeet) meters")// Prints "Three feet is 0.914399970739201 meters"
由于這些屬性是只讀計算屬性,所以他們不需要加入關鍵字 get。
可以直接進行運算:
let aMarathon = 42.km + 195.mprint("A marathon is /(aMarathon) meters long")// Prints "A marathon is 42195.0 meters long"
值得注意的是:擴展可以添加新的計算屬性,但是他們不可以添加存儲屬性,或者為現有的屬性添加屬性觀察器。
初始化器
擴展可以向類添加新的方便初始化器,但是它們不能向類添加新的指定的初始化器或取消初始化器。 指定的初始化器和取消初始化器必須始終由原始類實現提供。
下面定義幾個結構體:
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()}
我們可以這樣來創建 Rect 實例(關于默認初始化器可以查看初始化部分的文章):
let defaultRect = Rect()let memberwiseRect = Rect(origin: Point(x: 2.0, y: 2.0), size: Size(width: 5.0, height: 5.0))
這時,我們可以擴展 Rect 結構體,為其添加新的初始化器:
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))// centerRect's origin is (2.5, 2.5) and its size is (3.0, 3.0)
方法
下面是為Int 類型添加一個叫repetitions的方法:
extension Int { func repetitions(task: () -> Void) { for _ in 0..<self { task() } }}
然后我們可以這樣調用這個方法:
3.repetitions { print("Hello!")}// Hello!// Hello!// Hello!
變異實例方法
添加了擴展的實例方法也可以修改(或變異)實例本身。 修改self或其屬性的結構和枚舉方法必須將實例方法標記為mutating,就像原始實現中的突變方法一樣。
如下面的例子:
extension Int { mutating func square() { self = self * self }}var someInt = 3someInt.square()// someInt is now 9
下標
想實現
代碼如下:
extension Int { subscript(digitIndex: Int) -> Int { var decimalBase = 1 for _ in 0..<digitIndex { decimalBase *= 10 } return (self / decimalBase) % 10 }}746381295[0]// returns 5746381295[1]// returns 9746381295[2]// returns 2746381295[8]// returns 7
如果下標越界,則返回0:
746381295[9]// returns 0, as if you had requested:0746381295[9]
嵌套類型
擴展添加嵌套類型:
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 } }}
現在嵌套的類型可以在任何 Int 值中使用:
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([3, 19, -27, 0, -6, 0, 7])// Prints "+ + - 0 - 0 + "
參考英語原文:
https://developer.apple.com/library/content/documentation/Swift/Conceptual/Swift_Programming_Language/Extensions.html#//apple_ref/doc/uid/TP40014097-CH24-ID151
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者使用Swift能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答