扩展

作者: Stago | 来源:发表于2020-05-18 19:52 被阅读0次

    扩展(Extension)

    • Swift中的扩展,有点类似于OC中的分类(Category)

    • 扩展可以为枚举、结构体、类、协议添加新功能

    可以添加方法、计算属性、下标、(便捷)初始化器、嵌套类型、协议等等

    • 扩展不能办到的事情
    • 不能覆盖原有的功能
    • 不能添加存储属性,不能向已有的属性添加属性观察器
    • 不能添加父类
    • 不能添加指定初始化器,不能添加反初始化器
    • ......

    计算属性、下标、方法、嵌套类型

    extension Double {
        var km: Double { self * 1_000.0 }
        var m: Double { self }
        var dm: Double { self / 10.0 }
        var cm: Double { self / 100.0 }
        var mm: Double { self / 1_000.0 }
    }
    
    extension Array {
        subscript(nullable idx: Int) -> Element? {
            if (startIndex..<endIndex).contains(idx) {
                return self[idx]
            }
            return nil
        }
    }
    
    extension Int {
        func repetitions(task: () -> Void) {
            for _ in 0..<self { task() }
        }
        mutating func square() -> Int {
            self = self * self
            return self
        }
        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
            }
        }
        subscript(digitIndex: Int) -> Int {
            var decimalBase = 1
            for _ in 0..<digitIndex { decimalBase *= 10 }
            return (self / decimalBase) % 10
        }
    }
    

    协议、初始化器

    class Person {
        var age: Int
        var name: String
        init(age: Int, name: String) {
            self.age = age
            self.name = name
        }
    }
    
    extension Person : Equatable {
        static func == (left: Person, right: Person) -> Bool {
            left.age == right.age && left.name == right.name
        }
        convenience init() {
            self.init(age: 0, name: "")
        }
    }
    
    • 如果希望自定义初始化器的同时,编译器也能够生成默认初始化器

    可以再扩展中编写自定义初始化器

    • required初始化器也不能写在扩展中
    struct Point {
        var x: Int = 0
        var y: Int = 0
    }
    extension Point {
        init(_ point: Point) {
            self.init(x: point.x, y: point.y)
        }
    }
    var p1 = Point()
    var p2 = Point(x: 10)
    var p3 = Point(y: 20)
    var p4 = Point(x: 10, y: 20)
    var p5 = Point(p4)
    

    协议

    • 如果一个类型已经实现了协议的所有要求,但是还没有声明它遵守了这个协议

    可以通过扩展来让它遵守这个协议

    protocol TestProtocol {
        func test()
    }
    class TestClass {
        func test() {
            print("test")
        }
    }
    extension TestClass : TestProtocol {}
    
    • 编写一个函数,判断一个正数是否为奇数?
    func isOdd<T: BinaryInteger>(_ i: T) -> Bool {
        i % 2 != 0
    }
    extension BinaryInteger {
        func isOdd() -> Bool { self % 2 != 0 }
    }
    

    泛型

    class Stack<E> {
        var elements = [E]()
        func push(_ element: E) {
            elements.append(element)
        }
        func pop() -> E { elements.removeLast() }
        func size() -> Int { elements.count }
    }
    // 扩展依然可以使用原类型中的泛型类型
    extension Stack {
        func top() -> E { elements.last! }
    }
    // 符合条件才扩展
    extension Stack : Equatable where E : Equatable {
        static func == (left: Stack, right: Stack) -> Bool {
            left.elements == right.elements
        }
    }
    

    相关文章

      网友评论

          本文标题:扩展

          本文链接:https://www.haomeiwen.com/subject/edupohtx.html