然而another method swizzling question,之前没有问过。
我想在我的应用程序中监视所有释放调用,因此我决定在NSObject上使用方法调配,以便可以监视所有类。实际代码已经被from here取出,但为了清楚起见,我还会将其添加到此处。
似乎虽然所有(大多数?)案例都有效,但这对UIView及其子女无效。
我期待着,即使UIView重写了这个方法,或者即使是调整它,在一天结束时这个方法最终会以原始发布方法结束,因此通过调整我的代码将被执行。
如果我对NSObject类上的UIView类和进行调整,那么调配工作就完美了。如果我把它放在NSOBject上,Swizzling在UIResponder类中工作正常。似乎UIView有一些自定义实现可以打破链条?
以下是我正在使用的代码:
#import <objc/runtime.h>
#import <UIKit/UIKit.h>
@implementation NSObject (SwizzleRelease)
- (void)xxx_release {
printf("Will release %s #%d\n", [NSStringFromClass([self class]) UTF8String], [self retainCount]);
[self xxx_release];
}
+ (void)load {
NSLog(@"LOADED");
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
Class class = [self class];
SEL originalSelector = @selector(release);
SEL swizzledSelector = @selector(xxx_release);
Method originalMethod = class_getInstanceMethod(class, originalSelector);
Method swizzledMethod = class_getInstanceMethod(class, swizzledSelector);
BOOL didAddMethod =
class_addMethod(class,
originalSelector,
method_getImplementation(swizzledMethod),
method_getTypeEncoding(swizzledMethod));
if (didAddMethod) {
class_replaceMethod(class,
swizzledSelector,
method_getImplementation(originalMethod),
method_getTypeEncoding(originalMethod));
} else {
method_exchangeImplementations(originalMethod, swizzledMethod);
}
});
}
@end