Runtime的方法交叉(Method Swizzling)检测控制器是否释放

什么是Method Swizzling,为什么要用Method Swizzling
Method Swizzling:方法交叉,交换两个方法的实现.为什么要交换两个方法的实现,因为我们无法修改系统的某些方法,通过自己写一个方法,然后利用Runtime的Method Swizzling去交换系统与自定义的方法的实现,这样,调用系统的方法时,其实就是执行我们自定义的方法.执行我们自定义方法就是调用系统的方法.比如.在项目开发中,控制器太多了,
在每个控制器的dealloc方法打印相关信息很麻烦.可以自定义custom_delloc方法,利用Method Swizzling进行交换.

Method Swizzling方法介绍
1. 获取方法的实现
Method class_getInstanceMethod(Class cls,SEL name)
2. 交换两个方法的实现
void method_exchangeImplementations(Method m1,Method m2)

Method Swizzling的使用
利用Method Swizzing检测控制器是否释放
给UIViewController添加一个分类,所有的控制器都能够使用
可以在+(void)load;或者+(void)initialize;任意一个方法中添加

#import "UIViewController+dealloc.h"

#import<objc/runtime>

@implementation UIViewController (dealloc)

#pragma mark - 当类第一次加载到内存的时候会调用这个方法,它要比main.m方法先执行

+(void)load{
Method method1 = class_getInstanceMethod([self class], NSSelectorFromString(@"dealloc"));
Method method2 = class_getInstanceMethod([self class], @selector(custom_delloc));
method_exchangeImplementations(method1, method2);
}

#pragma mark - 自定义的dealloc方法

- (void) custom_delloc{
NSLog(@"%s -%@ custom_dealloc",__FUNCTION__,self);

/*通过方法交换之后,执行系统的dealloc方法不会发生死循环,因为它会执行系统的dealloc方法,另外我们可能会在系统的dealloc方法中执行一些释放操作,,所以在自定义的dealloc方法中也要执行系统的dealloc方法,让系统方法实现一次dealloc*/

[self custom_delloc];

}

@end

猜你喜欢

转载自blog.csdn.net/u012581760/article/details/81109170