Swift 有些场景其实不必加 final

Swift 的访问权限控制有一个关键字是 final,加了 final 后表示这个类就是最终的样子了。有两个作用:

  • 不能被 override,因为是最终版了,所以不能被改。
  • 优化执行性能。因为所有的方法调用只有一个明确路径(不存在子类),不需要到 vtable 中去查一下。

听起来为了规范,所有的不需要考虑继承的类都应该加上 final,但是一个项目里这么多类都加上其实也有点累人。很多人不知道的是其实有一些场景不需要自己手动添加。

私有类/属性不用添加

如果你的类的访问属性是 private 或者 fileprivate,因为只有在当前文件才能被访问,天然就不存在被外部访问继承的可能性,编译器会自动推断添加 final。所以这种情况下不用添加 final

默认访问权限(internal)也不用加

如果我们不添加访问权限,默认的访问权限的级别是 internal,表示只有当前 framework 内可以被访问。如果我们选择的编译模式是Whole Module Optimization (WMO),那么我们也不需要手动添加 final

因为 WMO 会把所有文件合并到一起进行性能优化,因此编译器知道一个类是否有子类,因此可以自动推断添加。

默认 release 的编译模式就是 Whole Module。

当然如果你是几个人维护一个项目,这个你写的类主观上不希望被继承,添加 final 是为了警示未来的使用者,那么主动添加也是一个好习惯。起到强文档的作用。

Public 需要主动加

如果你提供的是一个库给上层调用,添加了 public 后需要主动判断是否需要添加 final。因为标记了 public 类的调用者是未知的,如果不添加默认就是支持被继承的。如果你的类不支持继承,主动添加 final 可以优化性能。


Should you add final to all your Swift classes?

相关推荐
懋学的前端攻城狮13 小时前
iOS 列表性能优化实战:从 45fps 到 60fps 的蜕变
ios·性能优化·ui kit
斯班奇的好朋友阿法法13 小时前
鸿蒙 vs iOS vs 微信小程序:开发平台全面对比
ios·微信小程序·harmonyos
@大迁世界1 天前
14个你现在必须关闭的 iOS 26 设置,不然手机很快被它榨干
macos·ios·智能手机·objective-c·cocoa
四眼蒙面侠1 天前
深入 SwiftWork(第 0 篇):用 SwiftUI 构建一个 Agent 可视化工作台
swift·openagentsdk
YJlio1 天前
10.2.8 以其他账户运行服务(Running services in alternate accounts):为什么“把服务切到某个用户账号下运行”,本质上是在改变服务的整个安全上下文?
python·安全·ios·机器人·django·iphone·7-zip
pop_xiaoli2 天前
【iOS】KVC与KVO
笔记·macos·ios·objective-c·cocoa
90后的晨仔2 天前
《swiftUI进阶 第10章:现代状态管理(iOS 17+)》
ios
sakiko_2 天前
UIKit学习笔记4-使用UITableView制作滚动视图
笔记·学习·ios·swift·uikit
小锋学长生活大爆炸2 天前
【开源软件】这次iPhone也是用上Claw了 | PhoneClaw
ios·开源软件·iphone·claw
SameX2 天前
独立开发一个把走过的路变成 km² 的 App,聊聊 25m 网格和后台 GPS 的坑
ios