Swift教學
Swift快速入門
Swift簡介
Swift基礎
Swift常量和變量
Swift註釋
swift分號
Swift整數
Swift浮點數
Swift類型安全和類型推斷
swift數值型字面量
Swift數值型類型轉換
Swift類型別名
Swift布爾值
Swift元組
Swift可選類型
Swift斷言
Swift基本運算符
Swif哈希集合
Swift運算術語
Swift字典
Swift賦值運算符
Swift數值運算
Swift複合賦值
Swift比較運算
Swift三元條件運算
Swift區間運算符
Swift邏輯運算
Swift字符串和字符
Swift字符串字面量
Swift初始化空字符串
Swift字符串可變性
Swift字符串是值類型
Swift使用字符
Swift計算字符數量
Swift連接字符串和字符
Swift字符串插值
Swift比較字符串
Swift大寫和小寫字符串
Swift Unicode
Swift集合類型 (Collection Types)
Swift數組
Swift字典
Swift集合的可變性
Swift控制流
Swift For循環
Swift While循環
Swift條件語句
Swift控制轉移語句
Swift函數
Swift函數的定義與調用
Swift函數參數與返回值
Swift函數參數名稱
Swift函數類型
Swift嵌套函數
Swift閉包
Swift閉包表達式
Swift尾隨閉包
Swift捕獲值
Swift閉包是引用類型
Swift枚舉
Swift枚舉語法
Swift匹配枚舉值和Switch語句
Swift相關值
Swift原始值
Swift類和結構體
Swift類和結構體對比
Swift結構體和枚舉是值類型
Swift類是引用類型
Swift類和結構體的選擇
Swift集合(Collection)類型的賦值和拷貝行爲
Swift屬性
Swift存儲屬性
Swift計算屬性
Swift屬性監視器
Swift全局變量和局部變量
Swift類型屬性
Swift方法
Swift實例方法
Swift類型方法
Swift下標腳本
Swift下標腳本語法
Swift下標腳本用法
Swift下標腳本選項
Swift繼承
Swift定義一個基類
Swift子類生成
Swift重寫
Swift防止重寫
Swift構造過程
Swift存儲型屬性的初始賦值
Swift定製化構造過程
Swift默認構造器
Swift值類型的構造器代理
Swift類的繼承和構造過程
Swift通過閉包和函數來設置屬性的默認值
Swift析構過程
Swift析構過程原理
Swift析構函數操作
Swift自動引用計數
Swift自動引用計數的工作機制
Swift自動引用計數實踐
Swift類實例之間的循環強引用
Swift解決實例之間的循環強引用
Swift閉包引起的循環強引用
Swift解決閉包引起的循環強引用
Swift可選鏈
Swift可選鏈可替代強制解析
Swift爲可選鏈定義模型類
Swift通過可選鏈調用屬性
Swift通過可選鏈調用方法
Swift使用可選鏈調用子腳本
Swift連接多層鏈接
Swift鏈接可選返回值的方法
Swift類型轉換
Swift定義一個類層次作爲例子
Swift檢查類型
Swift向下轉型
Swift Any和AnyObject類型轉換
Swift嵌套類型
Swift嵌套類型實例
Swift嵌套類型的引用
Swift擴展
Swift擴展語法
Swift計算型屬性
Swift構造器
Swift方法擴展
Swift下標
Swift嵌套類型擴展
Swift協議
Swift協議的語法
Swift屬性要求
Swift方法要求
Swift突變方法要求
Swift協議類型
Swift委託(代理)模式
Swift在擴展中添加協議成員
Swift通過擴展補充協議聲明
Swift集合中的協議類型
Swift協議的繼承
Swift協議合成
Swift檢驗協議的一致性
Swift可選協議要求
Swift泛型
Swift泛型所解決的問題
Swift泛型函數
Swift類型參數
Swift命名類型參數
Swift泛型類型
Swift類型約束
Swift關聯類型
Swift Where語句
Swift高級運算符
Swift位運算符
Swift溢出運算符
Swift優先級和結合性
Swift運算符函數
Swift自定義運算符
Swift語法結構
Swift空白與註釋
Swift標識符
Swift關鍵字
Swift字面量
Swift運算符
Swift類型
Swift類型註解
Swift類型標識符
Swift元組類型
Swift函數類型(參數類型和返回值類型)
Swift數組類型
Swift可選類型(命名型類型)
Swift隱式解析可選類型
Swift協議合成類型
Swift元類型
Swift類型繼承子句
Swift類型推斷
Swift表達式
Swift前綴表達式
Swift二元表達式
Swift賦值表達式
Swift類型轉換運算符
Swift主表達式
Swift後綴表達式
Swift語句
Swift循環語句
Swift For語句
Swift分支語句
Swift帶標籤的語句
Swift聲明
Swift模塊範圍
Swift代碼塊
Swift引入聲明
Swift常量聲明
Swift類型的別名聲明
Swift函數聲明
Swift枚舉聲明
Swift結構體聲明
Swift類聲明
Swift協議聲明
Swift構造器聲明
Swift析構聲明
Swift擴展聲明
Swift下標腳本聲明
Swift運算符聲明
Swift變量聲明
Swift特性
Swift聲明特性
Swift類型特性
Swift模式
Swift通配符模式
Swift標識符模式
Swift值綁定模式
Swift元組模式
Swift枚舉用例模式
Swift類型轉換模式
Swift表達式模式
Swift泛型參數
Swift泛型形參子句
Swift開發環境設置
Swift基本語法
Swift數據類型
Swift變量
Swift常量
Swift字面量
Swift運算符
Swift比較運算符
Swift邏輯運算符
Swift位運算符
Swift賦值運算符
Swift範圍運算符
Swift其它運算符
Swift運算符優先級
Swift算術運算符
Swift if語句
Swift if...else語句
Swift if...else if...else語句
Swift嵌套 if 語句
Swift Switch語句
Swift決策
Swift for-in循環
Swift for循環
Swift while循環
Swift do...while循環
Swift continue語句
Swift break語句
Swift fallthrough語句
Swift循環
Swift字符串
Swift字符
Swift數組
Swift函數
Swift閉包
Swift枚舉
Swift結構體
Swift類
Swift 屬性
Swift 方法
Swift 下標
Swift 繼承
Swift初始化
Swift 反初始化
Swift ARC自動引用計數
Swift 可選鏈
Swift 類型轉換
Swift 擴展
Swift 協議
Swift 泛型
Swift訪問控制

Swift 協議

協議爲方法,屬性和其他要求的功能提供了一個藍本。它只是描述了方法或屬性的骨架,而不是實現。方法和屬性實現還可以通過定義類,函數和枚舉完成。協議的一致性是指方法或屬性滿足協議的要求。

語法

協議也遵循類似類,結構和枚舉的語法:

protocol SomeProtocol { // protocol definition }

協議在類,結構或枚舉類型命名聲明。單個和多個協議的聲明也是可以的。如果多個協議規定,它們必須用逗號分隔。

struct SomeStructure: Protocol1, Protocol2 { // structure definition }

當一個協議在超類中定義,協議名稱應遵循命名在超類之後。

class SomeClass: SomeSuperclass, Protocol1, Protocol2 { // class definition }

屬性和方法的要求

協議用於指定特定類型的屬性或屬性的實例。它僅指定類型或實例屬性單獨而不是指定它是否是一個存儲或計算屬性。另外,它是用來指定的屬性是否爲「可獲取'或'可設置」。

屬性要求由 「var」 關鍵字作爲屬性變量聲明。 {get set} 使用它們類型聲明後聲明屬性可獲取和可設置。 可獲取是由它們的類型{get}取屬性聲明後提及。

protocol classa { var marks: Int { get set } var result: Bool { get } func attendance() -> String func markssecured() -> String } protocol classb: classa { var present: Bool { get set } var subject: String { get set } var stname: String { get set } } class classc: classb { var marks = 96 let result = true var present = false var subject = "Swift Protocols" var stname = "Protocols" func attendance() -> String { return "The \(stname) has secured 99% attendance" } func markssecured() -> String { return "\(stname) has scored \(marks)" } } let studdet = classc() studdet.stname = "Swift" studdet.marks = 98 studdet.markssecured() println(studdet.marks) println(studdet.result) println(studdet.present) println(studdet.subject) println(studdet.stname)

當我們使用 playground 運行上面的程序,得到以下結果。

98
true
false
Swift Protocols
Swift

不同變形方法要求

protocol daysofaweek { mutating func print() } enum days: daysofaweek { case sun, mon, tue, wed, thurs, fri, sat
mutating func print() { switch self { case sun: self = sun
println("Sunday") case mon: self = mon
println("Monday") case tue: self = tue
println("Tuesday") case wed: self = wed
println("Wednesday") case mon: self = thurs
println("Thursday") case tue: self = fri
println("Friday") case sat: self = sat
println("Saturday") default: println("NO Such Day") } } } var res = days.wed
res.print()

當我們使用 playground 運行上面的程序,得到以下結果。

Wednesday

初始化程序要求

Swift 允許用戶初始化協議遵循類似於正常初始化類型的一致性。

語法

protocol SomeProtocol { init(someParameter: Int) }

示例

protocol tcpprotocol { init(aprot: Int) }

協議初始化程序要求類實現

指定或初始化便捷允許用戶初始化協議來預留「required」關鍵字,以符合其標準。

class SomeClass: SomeProtocol { required init(someParameter: Int) { // initializer implementation statements } } protocol tcpprotocol { init(aprot: Int) } class tcpClass: tcpprotocol { required init(aprot: Int) { } }

協議一致性保證所有子類顯式或繼承實現「required」修辭符。

當一個子類覆蓋其超類的初始化必須由「override」修飾符關鍵字指定。

protocol tcpprotocol { init(no1: Int) } class mainClass { var no1: Int // local storage init(no1: Int) { self.no1 = no1 // initialization } } class subClass: mainClass, tcpprotocol { var no2: Int init(no1: Int, no2 : Int) { self.no2 = no2 super.init(no1:no1) } // Requires only one parameter for convenient method required override convenience init(no1: Int) { self.init(no1:no1, no2:0) } } let res = mainClass(no1: 20) let print = subClass(no1: 30, no2: 50) println("res is: \(res.no1)") println("res is: \(print.no1)") println("res is: \(print.no2)")

當我們使用 playground 運行上面的程序,得到以下結果。

res is: 20
res is: 30
res is: 50

協議作爲類型

相反,在協議執行的功能被用作函數,類,方法等類型。

協議可以訪問作爲類型:

  • 函數,方法或初始化作爲一個參數或返回類型

  • 常量,變量或屬性

  • 數組,字典或其他容器作爲項目

protocol Generator { typealias members
func next() -> members? } var items = [10,20,30].generate() while let x = items.next() { println(x) } for lists in map([1,2,3], {i in i*5}) { println(lists) } println([100,200,300]) println(map([1,2,3], {i in i*10}))

當我們使用 playground 運行上面的程序,得到以下結果。

10
20
30
5
10
15
[100, 200, 300]
[10, 20, 30]

添加協議一致性與擴展

已有的類型可以通過和利用擴展符合新的協議。新屬性,方法和下標可以被添加到現有的類型在擴展的幫助下。

protocol AgeClasificationProtocol { var age: Int { get } func agetype() -> String } class Person { let firstname: String let lastname: String var age: Int init(firstname: String, lastname: String) { self.firstname = firstname self.lastname = lastname self.age = 10 } } extension Person : AgeClasificationProtocol { func fullname() -> String { var c: String c = firstname + " " + lastname return c } func agetype() -> String { switch age { case 0...2: return "Baby" case 2...12: return "Child" case 13...19: return "Teenager" case let x where x > 65: return "Elderly" default: return "Normal" } } }

協議繼承

Swift 允許協議繼承其定義的屬性的屬性。它類似於類的繼承,但用逗號分隔列舉選擇多個繼承協議。

protocol classa { var no1: Int { get set } func calc(sum: Int) } protocol result { func print(target: classa) } class student2: result { func print(target: classa) { target.calc(1) } } class classb: result { func print(target: classa) { target.calc(5) } } class student: classa { var no1: Int = 10 func calc(sum: Int) { no1 -= sum
println("Student attempted \(sum) times to pass") if no1 <= 0 { println("Student is absent for exam") } } } class Player { var stmark: result! init(stmark: result) { self.stmark = stmark } func print(target: classa) { stmark.print(target) } } var marks = Player(stmark: student2()) var marksec = student() marks.print(marksec) marks.print(marksec) marks.print(marksec) marks.stmark = classb() marks.print(marksec) marks.print(marksec) marks.print(marksec)

當我們使用 playground 運行上面的程序,得到以下結果。

Student attempted 1 times to pass
Student attempted 1 times to pass
Student attempted 1 times to pass
Student attempted 5 times to pass
Student attempted 5 times to pass
Student is absent for exam
Student attempted 5 times to pass
Student is absent for exam

只有類協議

當協議被定義,並且用戶想要定義協議與它應該通過定義類第一後跟協議的繼承列表被添加的類。

protocol tcpprotocol { init(no1: Int) } class mainClass { var no1: Int // local storage init(no1: Int) { self.no1 = no1 // initialization } } class subClass: mainClass, tcpprotocol { var no2: Int init(no1: Int, no2 : Int) { self.no2 = no2 super.init(no1:no1) } // Requires only one parameter for convenient method required override convenience init(no1: Int) { self.init(no1:no1, no2:0) } } let res = mainClass(no1: 20) let print = subClass(no1: 30, no2: 50) println("res is: \(res.no1)") println("res is: \(print.no1)") println("res is: \(print.no2)")

當我們使用 playground 運行上面的程序,得到以下結果。

res is: 20
res is: 30
res is: 50

協議組合

Swift 允許多個協議在協議組合的幫助下調用一次。

語法

protocol<SomeProtocol, AnotherProtocol>

示例

protocol stname { var name: String { get } } protocol stage { var age: Int { get } } struct Person: stname, stage { var name: String var age: Int } func print(celebrator: protocol<stname, stage>) { println("\(celebrator.name) is \(celebrator.age) years old") } let studname = Person(name: "Priya", age: 21) print(studname) let stud = Person(name: "Rehan", age: 29) print(stud) let student = Person(name: "Roshan", age: 19) print(student)

當我們使用 playground 運行上面的程序,得到以下結果。

Priya is 21 years old
Rehan is 29 years old
Roshan is 19 years old

檢查協議一致性

協議一致性是 is 和 as 類似於類型轉換的操作符測試。

  • 如果一個實例符合協議標準,is運算符如果失敗返回false ,否則返回true。

  • as? 版本是向下轉型操作符,返回協議的類型的可選值,並且如果該值是nil ,實例不符合該協議。

  • as 版是向下轉型操作符,強制向下轉型的協議類型並觸發一個運行時錯誤,如果向下轉型不會成功。

import Foundation @objc protocol rectangle { var area: Double { get } } @objc class Circle: rectangle { let pi = 3.1415927 var radius: Double var area: Double { return pi * radius * radius } init(radius: Double) { self.radius = radius } } @objc class result: rectangle { var area: Double init(area: Double) { self.area = area } } class sides { var rectsides: Int init(rectsides: Int) { self.rectsides = rectsides } } let objects: [AnyObject] = [Circle(radius: 2.0),result(area: 198),sides(rectsides: 4)] for object in objects { if let objectWithArea = object as? rectangle { println("Area is \(objectWithArea.area)") } else { println("Rectangle area is not defined") } }

當我們使用 playground 運行上面的程序,得到以下結果。

Area is 12.5663708
Area is 198.0
Rectangle area is not defined