概念
- Swift中的扩展,有点类似于OC的分类(Category)
- 扩展可以为枚举、结构体、类、协议添加新功能
- 可以添加方法、计算属性、下标、(便捷)初始化器、嵌套类型、协议等等
扩展不难办到的事情
- 不能覆盖原有的功能
- 不能添加存储属性,不能向已有的属性添加属性观察器
- 不能添加父类
- 不能添加指定初始化器,不能添加反初始化器
计算属性、下标、方法、嵌套类型
extension Double {
var km: Double {self * 1_000.0}
}
var numer:Double = 10.0
print(numer.km)
协议
protocol Rule {
func rule1()
}
class TestClass {
func rule1() {
print("rule1")
}
}
extension TestClass : Rule {
}
- 如果一个类型已经实现了协议的所有要求,但是还没有声明它遵守了这个协议
- 可以通过扩展来让他遵守这个协议
protocol TestProtocol {
func test1()
}
extension TestProtocol {
func test1() {
print("TestProtocol test1")
}
func test2() {
print("TestProtocol test2")
}
}
class TestClass1: TestProtocol {
}
var cls = TestClass1()
cls.test1()
cls.test2()
var cls2:TestProtocol = TestClass1()
cls2.test1()
cls2.test2()
- 扩展可以给协议提供默认方法,也间接实现【可选协议】的效果
- 扩展可以给协议扩充【协议中从未声明过的方法】
初始化器
struct Point {
var x: Int = 10
var y: Int = 10
}
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:10)
var p4 = Point(x: 10, y: 10)
var p5 = Point(p4)
泛型
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!
}
}
//符合条件才扩展
- 扩展中依然可以使用原类型中的泛型类型
网友评论