Objective-C 的动态性主要由以下几个关键特性和机制支撑:
1. 动态消息传递
objectivec
// 消息传递机制
id objc_msgSend(id self, SEL _cmd, ...) {
// 1. 获取类信息
Class cls = object_getClass(self);
// 2. 查找方法实现
IMP imp = lookUpImpOrForward(cls, _cmd);
// 3. 执行方法
return imp(self, _cmd, ...);
}
// 动态调用
[object performSelector:@selector(methodName)];
2. 动态类型
objectivec
// id 类型
id obj = [[NSObject alloc] init];
// 动态类型检查
if ([obj isKindOfClass:[NSString class]]) {
// 运行时检查类型
}
- id 类型:可以指向任何对象,类型信息在运行时确定。
- 动态类型检查:使用 isKindOfClass: 和 respondsToSelector: 等方法在运行时检查类型。
3. 动态方法解析
objectivec
// 动态方法解析
+ (BOOL)resolveInstanceMethod:(SEL)sel {
if (sel == @selector(dynamicMethod)) {
class_addMethod(self, sel, (IMP)dynamicMethodIMP, "v@:");
return YES;
}
return [super resolveInstanceMethod:sel];
}
- 方法解析:在运行时动态添加方法实现。
- resolveInstanceMethod::允许在方法未找到时提供实现。
4. 方法交换 (Method Swizzling)
objectivec
// 方法交换
Method originalMethod = class_getInstanceMethod(self, @selector(originalMethod));
Method swizzledMethod = class_getInstanceMethod(self, @selector(swizzledMethod));
method_exchangeImplementations(originalMethod, swizzledMethod);
5. 动态类和对象
objectivec
// 动态创建类
Class newClass = objc_allocateClassPair([NSObject class], "NewClass", 0);
objc_registerClassPair(newClass);
// 动态添加属性
class_addIvar(newClass, "dynamicIvar", sizeof(id), log2(sizeof(id)), @encode(id));
- 动态类创建:可以在运行时创建新类。
- 动态属性和方法:可以在运行时添加属性和方法。
6. 关联对象
objectivec
// 关联对象
objc_setAssociatedObject(obj, @selector(associatedObject), value, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
id value = objc_getAssociatedObject(obj, @selector(associatedObject));
- 关联对象:在运行时为对象动态添加属性。
7. 反射机制
objectivec
// 反射
Class cls = [obj class];
Method *methods = class_copyMethodList(cls, &methodCount);
- 反射:在运行时获取类和对象的详细信息。
8. 运行时库
- Objective-C Runtime Library:提供了丰富的 API 支持动态特性,如 objc_getClass、class_addMethod、method_getImplementation 等。
这些特性使得 Objective-C 能够在运行时灵活地处理对象和方法,支持动态行为和元编程。