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訪問控制

限制訪問代碼塊,模塊和抽象通過訪問控制來完成。類,結構和枚舉可以根據自己的屬性,方法,初始化函數和下標來通過訪問控制機制進行訪問。常量,變量和函數的協議限制,並允許通過訪問控制來訪問全局和局部變量。應用於屬性,類型及函數的訪問控制可以被稱爲「實體」。

訪問控制模型是基於模塊和源文件的。

模塊定義爲代碼分配一個單獨的單元,並且可以使用import 關鍵字導入。源文件被定義爲一個單一的源代碼文件,模塊可訪問多種類型和函數。

三種不同的訪問級別是由 Swift 語言提供。它們分別是 Public, Internal 和 Private 訪問。

方法級別

定義

Public

啓用實體可以以任何源文件從它們的定義模塊處理,導入已定義模塊到另一個模塊的源文件中。

Internal

從它們定義模塊啓用實體被包含在任何的源文件,但不是在模塊的外部的任何源文件。

Private

限制使用一個實體的自身限定源文件。private訪問扮演的角色是隱藏一個特定代碼功能的實現細節。

語法

public class SomePublicClass {} internal class SomeInternalClass {} private class SomePrivateClass {} public var somePublicVariable = 0 internal let someInternalConstant = 0 private func somePrivateFunction() {}

對於函數類型的訪問控制

某些函數可能有參數在函數聲明中但沒有任何返回值。下面的程序聲明 a 和 b 作爲參數傳遞給sum()函數。內部函數本身爲參數a和b的值是通過調用所述通過調用函數 sum(),其值被打印從而不用返回值。爲了使函數的返回類型爲私有,聲明函數使用 private 修飾整體訪問級別。

private func sum(a: Int, b: Int) { let a = a + b let b = a - b
println(a, b) } sum(20, 10) sum(40,10) sum(24,6)

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

(30, 20)
(50, 40)
(30, 24)

對於枚舉類型的訪問控制

public enum Student{ case Name(String) case Mark(Int,Int,Int) } var studDetails = Student.Name("Swift") var studMarks = Student.Mark(98,97,95) switch studMarks { case .Name(let studName): println("Student name is: \(studName).") case .Mark(let Mark1, let Mark2, let Mark3): println("Student Marks are: \(Mark1),\(Mark2),\(Mark3).") default: println("Nothing") }

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

Student Marks are: 98,97,95

枚舉在Swift語言中將自動接收枚舉個體並都具有相同的訪問級別。例如,考慮訪問固定於三個科目枚舉名稱,學生的名字和標記被聲明爲 student 而存在於枚舉類中的成員都屬於字符串數據類型名稱,標記表示爲 mark1, mark2 和 mark3 數據類型爲整數。要訪問無論是學生名稱或標記分數。 現在,如果被執行 Switch case 塊將打印學生姓名,否則它將打印由學生固定的標記。如果這兩個條件都失敗默認塊將被執行。

子類訪問控制

Swift 允許用戶子類,可以在當前訪問上下文存取的任何類。子類不能比其超類有更高的訪問級別。 用戶限制一個公共子類寫入一個內部超類。

public class cricket { private func print() { println("Welcome to Swift Super Class") } } internal class tennis: cricket { override internal func print() { println("Welcome to Swift Sub Class") } } let cricinstance = cricket() cricinstance.print() let tennisinstance = tennis() tennisinstance.print()

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

Welcome to Swift Super Class
Welcome to Swift Sub Class

常量,變量,屬性和下標訪問控制

Swift 常量,變量或屬性不能被定義比其類型更公開。這是無效一個 public 屬性與 private 類型的寫法。同樣,下標不能超過其索引或返回類型更公開。

當一個常量,變量,屬性或下標使用了一個私有類型,則常量,變量,屬性或下標,也必須標記爲私有:

private var privateInstance = SomePrivateClass()

Getters 和 Setters

getter和setter常量,變量,屬性和標自動接收它們屬於相同的訪問級別的常量,變量,屬性或下標。

class Samplepgm { private var counter: Int = 0{ willSet(newTotal){ println("Total Counter is: \(newTotal)") } didSet{ if counter > oldValue { println("Newly Added Counter \(counter - oldValue)") } } } } let NewCounter = Samplepgm() NewCounter.counter = 100 NewCounter.counter = 800

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

Total Counter is: 100
Newly Added Counter 100
Total Counter is: 800
Newly Added Counter 700

訪問控制的初始化和默認初始化器

自定義初始化函數可分配的接入級別小於或等於它們初始化的類型。一個必需的初始化必須具有相同的訪問級別,因爲它們和類相同。一個初始化的參數的類型不能比初始化自己的訪問級別更私密(更高)。

聲明每個和初始化每個子類, 「required」 關鍵字需要在init()函數之前定義。

class classA { required init() { var a = 10 println(a) } } class classB: classA { required init() { var b = 30 println(b) } } let res = classA() let print = classB()

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

10
30
10

默認初始化具有相同的訪問級別,因爲它初始化,除非該類型被定義爲公共類型。 當默認初始化定義爲公共它被認爲是內部的。當用戶需要一個公共類型在另一個模塊中的一個無參數初始化進行初始化,明確提供一個公共的無參數初始化作爲類型定義的一部分。

對於協議的訪問控制

當我們定義一個新的協議,從現有的協議繼承的功能,既有聲明相同的訪問級別以相互繼承屬性。Swift 訪問控制允許用戶定義 「public」 協議,它繼承自 「internal」 的協議。

public protocol tcpprotocol { init(no1: Int) } public 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 不允許用戶爲擴展提供一個明確的訪問級別修飾符。對於在每個協議的擴展,要求實現的默認訪問級別設置自己的協議訪問級別。

對於泛型訪問控制

泛型允許用戶指定最小訪問級別來訪問類型約束其類型參數。

public struct TOS<T> { var items = [T]() private mutating func push(item: T) { items.append(item) } mutating func pop() -> T { return items.removeLast() } } var tos = TOS<String>() tos.push("Swift") println(tos.items) tos.push("Generics") println(tos.items) tos.push("Type Parameters") println(tos.items) tos.push("Naming Type Parameters") println(tos.items) let deletetos = tos.pop()

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

[Swift]
[Swift, Generics]
[Swift, Generics, Type Parameters]
[Swift, Generics, Type Parameters, Naming Type Parameters]

對於類型別名訪問控制

用戶可以定義類型別名對待不同的訪問控制類型。 相同的訪問級別或不同的訪問級別可以由用戶定義。當類型別名爲 「private」 及其相關成員可以聲明爲 「private,內部 public 類型 」。當類型別名是公共成員不能是別名爲 「internal」 或 「private」 的名稱

定義任何類型別名被視爲用於不同類型的訪問控制的目的。一個類型別名可以具有小於或等於它的一個訪問級別別名的類型的訪問級別。例如,private類型別名可以別名爲 private, internal, 或 public,而 public 類型別名不能別名爲 internal 或 private 類型。

public protocol Container { typealias ItemType mutating func append(item: ItemType) var count: Int { get } subscript(i: Int) -> ItemType { get } } struct Stack<T>: Container { // original Stack implementation var items = [T]() mutating func push(item: T) { items.append(item) } mutating func pop() -> T { return items.removeLast() } // conformance to the Container protocol mutating func append(item: T) { self.push(item) } var count: Int { return items.count } subscript(i: Int) -> T { return items[i] } } func allItemsMatch< C1: Container, C2: Container where C1.ItemType == C2.ItemType, C1.ItemType: Equatable> (someContainer: C1, anotherContainer: C2) -> Bool { // check that both containers contain the same number of items if someContainer.count != anotherContainer.count { return false } // check each pair of items to see if they are equivalent for i in 0..<someContainer.count { if someContainer[i] != anotherContainer[i] { return false } } // all items match, so return true return true } var tos = Stack<String>() tos.push("Swift") println(tos.items) tos.push("Generics") println(tos.items) tos.push("Where Clause") println(tos.items) var eos = ["Swift", "Generics", "Where Clause"] println(eos)

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

[Swift]
[Swift, Generics]
[Swift, Generics, Where Clause]
[Swift, Generics, Where Clause]