Swift Access Control訪問控制與斷言詳細介紹
訪問控制(Access Control)
1、在訪問權(quán)限控制這塊,Swift提供了5個不同的訪問級別(以下是從高到低排序,實體指被訪問級別修飾的內(nèi)容)
- open:允許在定義實體的模塊、其他模塊中訪問,允許其他莫模塊進行繼承、重寫(open只能用在類、類成員上)
- public:允許在定義實體的模塊、其他模塊中訪問,不允許其他模塊進行繼承、重寫
- internal:只允許在定義實體的模塊中訪問,不允許在其他模塊中訪問
- fileprivate:只允許在定義實體的源文件中訪問
- private:只允許在定義實體的封閉聲明中訪問
2、絕大部分實體默認都是internal級別
訪問級別的使用準(zhǔn)則
1、一個實體不可以被更低訪問級別的實體定義,比如
- 變量\常量類型 >= 變量\常量
- 參數(shù)類型、返回值類型 >= 函數(shù)
- 父類 >= 子類
- ……
元組類型
1、元組類型的訪問界別是所有成員類型最低的那個
internal struct Dog {} fileprivate class Person {} //(Dog, Person)的訪問級別是fileprivate fileprivate var data1: (Dog, Person) private var data2: (Dog, Person)
泛型類型
1、泛型類型的訪問級別是 類型的訪問級別 以及 所有泛型類型參數(shù)的訪問級別 中最低的那個
成員、嵌套類型
1、類型的訪問級別會影響成員(屬性、方法、初始化器、下標(biāo))嵌套類型的默認訪問級別
- 一般情況下,類型為private或fileprivate,那么成員\嵌套類型默認也是private或fileprivate
- 一般情況下,類型為internal或public,那么成員\嵌套類型默認是internal
2、直接在全局作用域下定義的private等價于fileprivate
private struct Dog { var age: Int = 0 func run() {} } fileprivate struct Person { var dog: Dog = Dog() mutating func walk() { dog.run() dog.age = 1 } }
3、子類重寫的成員訪問級別必須 >= 父類的成員訪問級別
getter與setter
1、getter、setter默認自動接收他們所屬環(huán)境的訪問級別
2、可以給setter單獨設(shè)置一個比getter更低的訪問級別,用以限制寫的權(quán)限
fileprivate(set) public var num = 10 class Person { private(set) var age = 0 fileprivate(set) public var weight: Int { set {} get { 10 } } internal(set) public subscript(index: Int) -> Int { set {} get { index } } }
初始化器
1、如果一個public類想在另一個模塊調(diào)用編譯生成的默認無參初始化器,必須顯式提供public的無參初始化器
因為public類的默認初始化器時internal級別的
2、required初始化器必須跟他所屬類擁有相同的訪問級別
3、如果結(jié)構(gòu)體有private\fileprivate的存儲實例屬性,那么它的成員初始化器也是private\fileprivate
否則默認就是internal
枚舉類型的case
1、不能給enum的每個case單獨設(shè)置訪問級別
2、每個case自動接收enum的訪問級別
public enum定義的case也是public
協(xié)議
1、協(xié)議中定義的要求(方法)自動接收協(xié)議的訪問級別,不能單獨設(shè)置訪問級別
public協(xié)議定義的要求(方法)也是public
2、協(xié)議實現(xiàn)的訪問級別必須 >= 類型的訪問級別,或者 >= 協(xié)議的訪問級別
擴展
1、如果有顯式設(shè)置擴展的訪問級別,擴展添加的成員自動接收擴展的訪問級別
2、如果沒有顯式設(shè)置擴展的訪問級別,擴展添加的成員的默認訪問級別,跟直接在類型中定義的成員一樣
3、可以單獨給擴展添加的成員設(shè)置訪問級別
4、不能給用于遵守協(xié)議的擴展顯式設(shè)置擴展的訪問級別
5、在同一文件中的擴展,可以寫成類似多個部分的類型聲明
- 在原本的聲明中聲明一個私有成員,可以在同一文件的擴展中訪問他
- 在擴展中聲明一個私有成員,可以在同一文件的其他擴展中、原本生明中訪問他
將方法賦值給var\let
1、方法也可以像函數(shù)那樣,賦值給一個let或者var
struct Person { var age: Int func run(_ v: Int) { print("func run", age, v) } } var fn: (Person) -> (Int) -> () = Person.run(_:) fn(Person(age: 10))(20)
一些補充知識
CustomStringConvertible
1、遵守CustomStringConvertible、CustomDebugStringConvertible協(xié)議,都可以自定義實例的打印字符串
class Person: CustomStringConvertible, CustomDebugStringConvertible { var age = 0 var description: String { "person_\(age)" } var debugDescription: String { "debug_person_\(age)" } }
2、print調(diào)用的是CustomStringConvertible協(xié)議的description
3、debugPrint、po調(diào)用的是CustomDebugStringConvertible協(xié)議的debugDescription
Self
1、Self一般用作返回值類型,限定返回值跟方法調(diào)用者必須是同一類型(也可以作為參數(shù)類型)
2、Self代表當(dāng)前類型
class Person { var age = 1 static var count = 2 func run() { print(self.age) // 1 print(Self.count) // 2 } }
assert (斷言)
1、很多編程語言都有斷言機制:不符合指定條件就拋出運行時錯誤,常用語調(diào)試(Debug)階段的條件判斷
2、默認情況下,Swift的斷言只會在debug模式下生效,release模式下會忽略
func divide(_ v1: Int, _ v2: Int) -> Int { assert(v2 != 0, "除數(shù)不能為0") return v1 / v2 }
fatalError
1、如果遇到嚴重問題,希望結(jié)束程序運行時,可以直接使用fatalError函數(shù)拋出錯誤(這是無法通過do-catch捕捉的錯誤)
2、使用了fatalError函數(shù),就不需要再寫return
func test(_ num: Int) -> Int { if num >= 0 { return 1 } fatalError("num不能小于0") }
3、在某些不得不實現(xiàn),但不希望別人調(diào)用的方法,可以考慮內(nèi)部使用fatalError函數(shù)
class Person { required init() {} } class Student: Person { required init() { fatalError("don't call Student init()") } init(score: Int) {} } var stu1 = Student(score: 98) var stu2 = Student()
到此這篇關(guān)于Swift Access Control訪問控制與斷言詳細介紹的文章就介紹到這了,更多相關(guān)Swift Access Control內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
簡單了解Swift語言中的break和continue語句的用法
這篇文章主要簡單介紹了Swift語言中的break和continue語句的用法,與其他語言的一樣用于循環(huán)語句流程控制,需要的朋友可以參考下2015-11-11swift4 使用DrawerController實現(xiàn)側(cè)滑菜單功能的示例代碼
這篇文章主要介紹了swift4 使用DrawerController實現(xiàn)側(cè)滑功能的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06使用Swift實現(xiàn)iOS App中解析XML格式數(shù)據(jù)的教程
這篇文章主要介紹了使用Swift實現(xiàn)iOS App中解析XML格式數(shù)據(jù)的教程,講到了iOS中提供的NSXMLParser和NSXMLParserDelegate兩個API的用法,需要的朋友可以參考下2016-04-04快速排序算法在Swift編程中的幾種代碼實現(xiàn)示例
快速排序是一種不穩(wěn)定的排序,存在著優(yōu)化空間,這里我們來看快速排序算法在Swift編程中的幾種代碼實現(xiàn)示例:2016-07-07