访问控制限制从其他源文件和模块中的代码访问你的某些代码。该特性使你能够隐藏代码的实现细节,并指定一个首选接口,通过该接口可以访问和使用代码。
你可以为单个类型(类、结构和枚举)以及属于这些类型的属性、方法、初始化器和下标分配特定的访问级别。协议可以限制在特定的上下文中,全局常量、变量和函数也是如此。
除了提供不同级别的访问控制外,Swift还通过为典型场景提供默认访问级别,减少了显式指定访问控制级别的需要。实际上,如果您正在编写一个单目标应用程序,您可能根本不需要指定显式访问控制级别。
一、模块和源文件
Swift的访问控制模型基于模块和源文件的概念。
模块是一个单独的代码分发单元——一个框架或应用程序,它作为一个单独的单元构建和发布,并且可以由另一个模块使用Swift的import
关键字导入。
Xcode中的每个构建目标(例如应用程序包或框架)都被视为Swift中的单独模块。 如果您将应用程序代码的各个方面组合在一起作为一个独立的框架 - 也许是为了跨多个应用程序封装和重用该代码 - 那么您在该框架中定义的所有内容都将在导入并在应用程序中使用时成为单独模块的一部分, 或者当它在另一个框架中使用时。
源文件是模块内的一个Swift源代码文件(实际上是应用程序或框架内的一个文件)。虽然在单独的源文件中定义单个类型很常见,但是单个源文件可以包含多个类型、函数等的定义。
二、访问级别
Swift代码中五种访问级别与定义实体的源文件和源文件所属的模块相关。open
的访问级别最高,private
的访问级别最低,internal
是默认的访问级别。
-
open
和public
:使实体在其所定义模块的源文件中,或通过导入其所定义模块在另一个模块的源文件中使用。而public
修饰的类或类成员只能在当前模块被继承或被子类重写;而open
则可以在另一个模块中被继承或被子类重写。在定义框架的公共接口时,通常使用open
和public
; -
internal
:使实体可以在其所定义模块的任何源文件中使用,但不能在其他模块的的源文件中使用。在定义应用程序或框架的内部结构时,通常使用internal
。 -
fileprivate
:使实体只能在其定义的源文件中使用。当这些详细信息在整个文件中使用时,使用fileprivate
隐藏特定功能块的实现细节。 -
private
:使实体在其所声明的类,以及同一文件中该声明的扩展中使用。当这些详细信息仅在单个声明中使用时,使用private
来隐藏特定功能的实现细节。
open
可以在不同模块中访问,public
只能在当前模块中访问,internal
系统默认的访问控制权限,fileprivate
可以被继承但不能被子类修改或重写,private
不能被继承。