美文网首页
18-Swift扩展

18-Swift扩展

作者: 一抹相思泪成雨 | 来源:发表于2020-12-20 20:46 被阅读0次

1.扩展

  • Swift中的扩展,有点类似于OC中的分类(Category)
  • 扩展可以为枚举、结构体、类、协议添加新功能
    • 可以添加方法、计算属性、下标、(便捷)初始化器、嵌套类型、协议等等
  • 扩展不能办到的事情:
    • 不能覆盖原有功能
    • 不能添加存储属性,不能向已有的属性添加属性观察器
    • 不能添加父类
    • 不能添加指定初始化器,不能添加反初始化器

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

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
    }
}

let a: [Int] = []
let b = a[nullable: 0]

extension Int {
    func repeats(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
    }
}

3.协议、 初始化器

  • 如果希望自定义初始化器的同时,编译器也能够生成默认初始化器
  • 可以在扩展中编写自定义初始化器
  • required初始化器也不能写在扩展中
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: "")
    }
}

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)

4.协议

  • 如果一个类型已经实现了协议的所有要求,但是还没有声明它遵守了这个协议
    • 可以通过扩展来让它遵守这个协议
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 }
}

/// 扩展可以给协议提供默认实现,也间接实现【可选协议】的效果
/// 扩展可以给协议扩充【协议中从未声明过的方法】
protocol TestProtocol1 {
    func test1()
}

extension TestProtocol1 {
    func test1() {
        print("TestProtocol1 test1")
    }
    func test2() {
        print("TestProtocol1 test2")
    }
}

class TestClass1 : TestProtocol1 {}
var cls = TestClass1()
cls.test1() // TestProtocol1 test1
cls.test2() // TestProtocol1 test2
var cls2: TestProtocol1 = TestClass1()
cls2.test1() // TestProtocol1 test1
cls2.test2() // TestProtocol1 test2

class TestClass2: TestProtocol1 {
    func test1() { print("TestClass test1") }
    func test2() { print("TestClass test2") }
}

print("---------")
var clss = TestClass2()
clss.test1() // TestClass test1
clss.test2() // TestClass test2
var clss2: TestProtocol1 = TestClass2()
clss2.test1() // TestClass test1
clss2.test2() // TestProtocol1 test2

5.泛型

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
    }
}

相关文章

  • 18-Swift扩展

    1.扩展 Swift中的扩展,有点类似于OC中的分类(Category) 扩展可以为枚举、结构体、类、协议添加新功...

  • 18-Swift扩展(Extensions)

    扩展就是向一个已有的类、结构体、枚举类型或协议类型添加新功能。而且还包括在没有权限获取原始源代码的情况下扩展类型的...

  • 18-Swift扩展(Extensions)

    扩展就是向一个已有的类、结构体、枚举类型或协议类型添加新功能。而且还包括在没有权限获取原始源代码的情况下扩展类型的...

  • 18-Swift之UIView(视图)

    1、UIView 的定义? 答:UIView 是视图。视图对象是一个应用中, 用户可以看到的对象。 视图对象知道如...

  • 18-Swift中的访问权限

    OC中的访问权限: @private:作用范围只能在自身类; @protected:作用范围在自身类和继承自己的子...

  • Swift 扩展

    扩展UIView 扩展String 扩展UIColor 扩展UIButton 扩展String 扩展UIImage...

  • ES6扩展

    字符串的扩展正则的扩展数值的扩展数组的扩展函数的扩展对象的扩展

  • ES6扩展

    字符串扩展 正则扩展 数值扩展 函数扩展 对象扩展 数组扩展 字符串扩展 模版字符串 部分新的方法 padStar...

  • Swift--扩展

    扩展的概念 扩展计算属性 扩展方法 扩展构造函数 扩展下标 扩展的概念 在Swift中可以使用一种扩展机制,在原有...

  • 从Java到Kotlin(六)

    扩展与委托 目录 1.扩展 1.1 扩展函数 1.2 扩展属性 1.3 扩展伴生对象 1.4 扩展的作用域 2.委...

网友评论

      本文标题:18-Swift扩展

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