访问控制
模块和源文件
Swift的访问控制模型基于模块和源文件的概念.
模块:如UIKit就是一个模块,你也可以自己定义自己的模块(静态库)
源文件:就是一个后缀为.swift的文件.
五个分级别访问控制
open 最高级别,修饰的类和成员允许被其他模块访问,继承和重写
1 | open class K1:NSObject{ |
public 修饰的类和成员可以被访问但不允许被其他模块继承和重写
1 | public class K1:NSObject{ |
internal 默认级别,可以被模块内任意文件访问,但是不能被模块之外的文件访问
1 | class K1:NSObject{ |
fileprivate 只允许当前文件访问,当前文件定义多个类,结构体等都可以访问
1 | fileprivate class K1:NSObject{ |
private 只允许当前类使用
1 | private class K1:NSObject{ |
元组的访问控制
元组类型的访问级别是所有类型里最严格的.例如,如果你将两个不同类型的元素组成一个元组,一个元素的访问级别是internal,另一个是private,那么这个元组类型是private 级别的.
枚举类型
1 | //所有成员都是public |
其他
继承子类的访问控制不能比父类的访问控制级别高.如父类是internal,那么子类就不能是public,协议的继承也是如此.
扩展的访问控制和被扩展的类,结构体,枚举保持一致.
泛指类型和泛指函数的访问级别取泛指类型或函数以及泛型类型参数的访问级别的最小值.
The End