Swift中用到extension的一些基本的擴(kuò)展功能講解
現(xiàn)有的類(lèi),結(jié)構(gòu)或枚舉類(lèi)型的功能可以在擴(kuò)展的幫助下加入。類(lèi)型的功能可以使用擴(kuò)展加入,但重寫(xiě)的功能不能使用擴(kuò)展。
Swift 擴(kuò)展功能:
- 添加計(jì)算屬性并計(jì)算類(lèi)型屬性
- 定義實(shí)例和類(lèi)型的方法
- 提供了新的初始化
- 定義下標(biāo)
- 定義和使用新的嵌套類(lèi)型
- 使現(xiàn)有類(lèi)型符合協(xié)議
擴(kuò)展用關(guān)鍵字 extension 聲明
語(yǔ)法
extension SomeType {
// new functionality can be added here
}
現(xiàn)有類(lèi)型也可以用擴(kuò)展加入使它作為一個(gè)協(xié)議標(biāo)準(zhǔn)和其語(yǔ)法類(lèi)似于類(lèi)或結(jié)構(gòu)。
extension SomeType: SomeProtocol, AnotherProtocol {
// protocol requirements is described here
}
計(jì)算屬性
計(jì)算“實(shí)例”和“type”屬性也可以擴(kuò)展在擴(kuò)展的幫助下實(shí)現(xiàn)。
extension Int {
var add: Int {return self + 100 }
var sub: Int { return self - 10 }
var mul: Int { return self * 10 }
var div: Int { return self / 5 }
}
let addition = 3.add
println("Addition is \(addition)")
let subtraction = 120.sub
println("Subtraction is \(subtraction)")
let multiplication = 39.mul
println("Multiplication is \(multiplication)")
let division = 55.div
println("Division is \(division)")
let mix = 30.add + 34.sub
println("Mixed Type is \(mix)")
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
Addition is 103 Subtraction is 110 Multiplication is 390 Division is 11 Mixed Type is 154
初始化器
Swift 能夠靈活地通過(guò)擴(kuò)展新的初始化添加到現(xiàn)有的類(lèi)型。用戶(hù)可以添加自己的自定義類(lèi)型來(lái)擴(kuò)展已定義的類(lèi)型,額外的初始化選項(xiàng)也是可以的。 擴(kuò)展僅支持 init(). 而 deinit() 不被擴(kuò)展支持。
struct sum {
var num1 = 100, num2 = 200
}
struct diff {
var no1 = 200, no2 = 100
}
struct mult {
var a = sum()
var b = diff()
}
let calc = mult()
println ("Inside mult block \(calc.a.num1, calc.a.num2)")
println("Inside mult block \(calc.b.no1, calc.b.no2)")
let memcalc = mult(a: sum(num1: 300, num2: 500),b: diff(no1: 300, no2: 100))
println("Inside mult block \(memcalc.a.num1, memcalc.a.num2)")
println("Inside mult block \(memcalc.b.no1, memcalc.b.no2)")
extension mult {
init(x: sum, y: diff) {
let X = x.num1 + x.num2
let Y = y.no1 + y.no2
}
}
let a = sum(num1: 100, num2: 200)
println("Inside Sum Block:\( a.num1, a.num2)")
let b = diff(no1: 200, no2: 100)
println("Inside Diff Block: \(b.no1, b.no2)")
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
Inside mult block (100, 200) Inside mult block (200, 100) Inside mult block (300, 500) Inside mult block (300, 100) Inside Sum Block:(100, 200) Inside Diff Block: (200, 100)
方法
新實(shí)例方法和類(lèi)型的方法,可以在擴(kuò)展的幫助下進(jìn)一步加入到子類(lèi)。
extension Int {
func topics(summation: () -> ()) {
for _ in 0..<self {
summation()
}
}
}
4.topics({
println("Inside Extensions Block")
})
3.topics({
println("Inside Type Casting Block")
})
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
Inside Extensions Block Inside Extensions Block Inside Extensions Block Inside Extensions Block Inside Type Casting Block Inside Type Casting Block Inside Type Casting Block
topics() 函數(shù)使用參數(shù)是 (summation: () -> ()) 的類(lèi)型表示該函數(shù)不帶任何參數(shù) 而且它不會(huì)返回任何值。調(diào)用該函數(shù)多次, 塊被初始化,并調(diào)用 topic()方法初始化。
不同實(shí)例方法變形
實(shí)例方法時(shí)也可以作為擴(kuò)展聲明的變形。
修改自身的結(jié)構(gòu)和計(jì)數(shù)的方法或它的屬性必須標(biāo)注實(shí)例方法變形,就像是從一個(gè)原始的實(shí)現(xiàn)變形的方法。
extension Double {
mutating func square() {
let pi = 3.1415
self = pi * self * self
}
}
var Trial1 = 3.3
Trial1.square()
println("Area of circle is: \(Trial1)")
var Trial2 = 5.8
Trial2.square()
println("Area of circle is: \(Trial2)")
var Trial3 = 120.3
Trial3.square()
println("Area of circle is: \(Trial3)")
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
Area of circle is: 34.210935 Area of circle is: 105.68006 Area of circle is: 45464.070735
下標(biāo)
添加新標(biāo)已聲明實(shí)例也可以擴(kuò)展。
extension Int {
subscript(var multtable: Int) -> Int {
var no1 = 1
while multtable > 0 {
no1 *= 10
--multtable
}
return (self / no1) % 10
}
}
println(12[0])
println(7869[1])
println(786543[2])
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
2 6 5
嵌套類(lèi)型
嵌套類(lèi)型為類(lèi),結(jié)構(gòu)和枚舉實(shí)例,也可在擴(kuò)展的幫助下進(jìn)行擴(kuò)展。
extension Int {
enum calc
{
case add
case sub
case mult
case div
case anything
}
var print: calc {
switch self
{
case 0:
return .add
case 1:
return .sub
case 2:
return .mult
case 3:
return .div
default:
return .anything
}
}
}
func result(numb: [Int]) {
for i in numb {
switch i.print {
case .add:
println(" 10 ")
case .sub:
println(" 20 ")
case .mult:
println(" 30 ")
case .div:
println(" 40 ")
default:
println(" 50 ")
}
}
}
result([0, 1, 2, 3, 4, 7])
當(dāng)我們使用 playground 運(yùn)行上面的程序,得到以下結(jié)果。
10 20 30 40 50 50
相關(guān)文章
Swift算法之二叉樹(shù)實(shí)現(xiàn)的方法示例
二叉樹(shù)是計(jì)算機(jī)科學(xué)中最基本也是最重要的樹(shù)型結(jié)構(gòu),最常見(jiàn)的二叉樹(shù)生成算法通常是使用遞歸或者其他描述類(lèi)語(yǔ)言的方法來(lái)實(shí)現(xiàn)。本文主要介紹了Swift算法之二叉樹(shù)實(shí)現(xiàn)的方法,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-03-03
利用swift實(shí)現(xiàn)卡片橫向滑動(dòng)動(dòng)畫(huà)效果的方法示例
卡片橫向滑動(dòng)動(dòng)畫(huà)效果相信對(duì)大家來(lái)說(shuō)都不陌生,下面這篇文章主要給大家介紹了關(guān)于利用swift實(shí)現(xiàn)卡片橫向滑動(dòng)動(dòng)畫(huà)效果的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07
Swift利用AFN實(shí)現(xiàn)封裝網(wǎng)絡(luò)請(qǐng)求詳解
網(wǎng)絡(luò)請(qǐng)求工具是我們經(jīng)常用到的工具類(lèi),所以下面這篇文章主要給大家介紹了關(guān)于Swift利用AFN如何實(shí)現(xiàn)封裝網(wǎng)絡(luò)請(qǐng)求的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10
Swift使用transform 實(shí)現(xiàn)重復(fù)平移動(dòng)畫(huà)效果
這篇文章主要介紹了Swift使用transform 實(shí)現(xiàn)重復(fù)平移動(dòng)畫(huà)效果,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-07-07
Swift利用指紋識(shí)別或面部識(shí)別為應(yīng)用添加私密保護(hù)功能
這篇文章主要給大家介紹了關(guān)于Swift利用指紋識(shí)別或面部識(shí)別為應(yīng)用添加私密保護(hù)功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用swift具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面隨著小編來(lái)一起看看吧2018-05-05

