理解 Objective-C 中 `+load` 方法的执行顺序

理解 Objective-C 中 +load 方法的执行顺序

在 Objective-C 中,+load 方法是在类或分类被加载到内存时调用的。它在程序启动过程中非常早的阶段执行,用于在类或分类被加载时进行一些初始化工作。理解 +load 方法的执行顺序对于编写可靠的 Objective-C 代码非常重要。本文将详细探讨 +load 方法在类、子类和分类中的执行顺序。

+load 方法的基本介绍

+load 方法是一个类方法,在类或分类被加载时自动调用。与 +initialize 方法不同,+load 方法只会被调用一次,并且在加载类和分类时立即执行,而不等待任何实例的创建。

类和子类中的执行顺序

当一个类和它的子类都实现了 +load 方法时,执行顺序如下:

  1. 父类的 +load 方法 先于 子类的 +load 方法 执行。
  2. 在同一个继承层次结构中,类的 +load 方法按照编译顺序执行。

例如,考虑以下代码:

objective-c 复制代码
#import <Foundation/Foundation.h>

@interface SuperClass : NSObject
@end

@implementation SuperClass
+ (void)load {
    NSLog(@"SuperClass +load");
}
@end

@interface SubClass : SuperClass
@end

@implementation SubClass
+ (void)load {
    NSLog(@"SubClass +load");
}
@end

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        // 程序启动时自动调用 `+load` 方法
    }
    return 0;
}

输出结果将是:

复制代码
SuperClass +load
SubClass +load

分类中的执行顺序

分类中的 +load 方法的执行顺序稍微复杂一些:

  1. 分类的 +load 方法 在其所属类的 +load 方法之后执行。
  2. 如果一个类有多个分类,那么分类的 +load 方法的执行顺序是不确定的。这意味着我们不应该依赖于分类的加载顺序来编写代码。

考虑以下示例:

objective-c 复制代码
@interface SubClass (Category1)
@end

@implementation SubClass (Category1)
+ (void)load {
    NSLog(@"SubClass (Category1) +load");
}
@end

@interface SubClass (Category2)
@end

@implementation SubClass (Category2)
+ (void)load {
    NSLog(@"SubClass (Category2) +load");
}
@end

在上述代码的基础上,输出结果可能是:

复制代码
SuperClass +load
SubClass +load
SubClass (Category1) +load
SubClass (Category2) +load

或:

复制代码
SuperClass +load
SubClass +load
SubClass (Category2) +load
SubClass (Category1) +load

父类分类的执行顺序

如果父类的分类也实现了 +load 方法,执行顺序如下:

  1. 父类的 +load 方法
  2. 父类分类的 +load 方法(按任意顺序)。
  3. 子类的 +load 方法
  4. 子类分类的 +load 方法(按任意顺序)。

考虑以下示例代码:

objective-c 复制代码
@interface SuperClass (Category)
@end

@implementation SuperClass (Category)
+ (void)load {
    NSLog(@"SuperClass (Category) +load");
}
@end

结合之前的代码,输出结果将是:

复制代码
SuperClass +load
SuperClass (Category) +load
SubClass +load
SubClass (Category1) +load
SubClass (Category2) +load
相关推荐
猫头虎4 小时前
如何解决 OpenClaw “Pairing required” 报错:两种官方解决方案详解
网络·windows·网络协议·macos·智能路由器·pip·scipy
游戏开发爱好者88 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
黑码哥9 小时前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder
2501_9151063210 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_9151063211 小时前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
熊猫钓鱼>_>11 小时前
移动端开发技术选型报告:三足鼎立时代的开发者指南(2026年2月)
android·人工智能·ios·app·鸿蒙·cpu·移动端
徐同保1 天前
通过ip访问nginx的服务时,被第一个server重定向了,通过设置default_server解决这个问题
ios·iphone
皮卡车厘子1 天前
Mac 挂载目录
macos
良逍Ai出海1 天前
在 Windows & macOS 上安装 Claude Code,并使用第三方 Key 的完整教程
windows·macos
热爱生活的五柒1 天前
linux/mac/wsl如何使用claude code,并配置免费的硅基流动API?(官方的需要付费订阅)
linux·运维·macos