Swift中所有单独的类型如类,结构体,枚举都能定义他的适用范围,也就是获取权限。属于这些类型的属性,方法,初始化方法和subscripts都能够指定他们的获取权限。
Swift的获取权限基于modules和source files文件
Module:是一个单独的发布单元,一个框架或一个应用,能够用import关键字在另外的一个地方导入
source file:在module当中一个单独的源代码文件
swift有三种指定的权限:
Public: 1 在module中的所有源文件都可用
2 导入该module中的所有源文件都可用
3 通常用在某个框架的公共接口上声明为public
Internal: 1 在该modul内的所有源文件
2 导入该module的module的源文件不可用
3 通常用在定义一个app或框架的内部结构
Private: 1 仅仅在定义他的源文件中可用
2 通常用他来隐藏具体功能的实现细节
使用规则:在一个具有低的获取权限的entity内部不能定义比该entity的获取权限高的entity
如:一个public公共变量不能定义在具有internal和private的类,枚举和结构体中
一个函数的获取权限不能比他的参数和返回类型的获取权限高
所有的entity都有一个默认的获取权限那就是internal
UnitTest能够获取任何的internal entity,但需要在导入某个module或文件时指定@testable
在某个源文件中定义一个私有的类,拿这个类即可以用作变量的类型,函数的参数和返回值
类型的获取类型影响他所包含的entity的获取类型,他所包含的entity的获取类型不赢该高于该类型的获取类型,如private 类,该类中的所有变量,方法等的获取权限就只能是private
tuple types:元组的获取类型十分的严格,如元组中一个元素是private,另外一个是public则该元组的获取类型只能是private
function types:函数的获取类型十分的严格,根据函数的参数的获取类型和返回值的获取类型计算而来,计算方法参考元组
Enumeration types:枚举类型的获取权限与他所包含的元素的获取权限相同,因此在枚举类型中不能包含不同的获取权限的元素
子类不能有比他的父类高的获取权限,子类的获取权限比父类的获取权限低一个层次
public classA{
private func someMethod() {}
}
internal classB:A{
override internal func someMethod() {
super.someMethod()
}
}
上面这段代码只有当类A,类B在同一个源文件中时才回成功
Constants, Variables, Properties, and Subscripts的获取权限不能比他的types的获取权限大。
在私有类型中的Constants, Variables, Properties, and Subscripts必须包含private
struct TrackedString{
private(set)var numberOfEdits=0
var value:String=""{
didSet{
numberOfEdits++
}
}
}
上面这段代码追踪一个字符串被设定的次数,结构体TrackedString与变量value具有相同的获取权限internal,变量numberOfEdits的set方法的权限被设定为private,这样只有在结构体所在的源文件中才能设定numberOfEdits的值,在其他的源文件中numberOfEdits就只能是readOnly
上面这段代码指定numberOfEdits的set方法的获取权限是private而get方法的获取权限是public
Intializers:自己定义的初始化方法的获取权限不能比类型的initlializer的初始化方法大,但对于required初始化方法的获取权限必须与所属类的初始化方法相同
Default Initializers:默认的初始化方法的获取权限与他所初始化的类的获取权限相同,但如果累的获取权限是public则该初始化方法的获取权限是internal
Protocols:一个类型可以遵从比类型获取权限低的protocol
Extensions:如果扩展的类型是public或是Internal,则在扩展中变量默认的获取权限是internal
如果扩展一个私有类型,则在扩展中变量默认的获取权限是private
Type Aliases:类型强制转换,一个私有类型能够强制转换为public和internal,private
一个private类型只能强制转化为private