(十三) [OC高效系列]用方法调配技术调试黑盒方法

不多说直接上代码

@interface NSString (YXMethodExchange)

- (NSString *)yx_uppercaseString;
@end


@implementation NSString (YXMethodExchange)

- (NSString *)yx_uppercaseString{
    NSLog(@"执行uppercaseString之前");
    //这里看似会递归,但实际并不会,因为实际调用的是uppercaseString方法
    NSString *uppercaseString = [self yx_uppercaseString];
     NSLog(@"执行uppercaseString之后 获取到大写:%@",uppercaseString);
    return uppercaseString;
}
@end

调用场景代码

 Method up = class_getInstanceMethod([NSString class], @selector(uppercaseString));
 Method myUp = class_getInstanceMethod([NSString class], @selector(yx_uppercaseString));
 method_exchangeImplementations(up, myUp);
 [@"hellow" uppercaseString];

这样就能在指定的方法调用前后加上输出日志。可以很方便的对IOS中没有暴露的方法进行日志打印,方便调试。这就是黑盒调试。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,477评论 25 708
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,251评论 4 61
  • 大风还在呼呼地挂着,感觉过不了多久小岛就会被这种无形的蛮力弄翻个个儿。那些棕榈树,平日里都是T型的,这两天都变F了...
    厨房里的xiao阅读 132评论 0 0
  • 今天是国庆节,伟大祖国的第68个生日,首先祝祖国妈妈,生日快乐。 我住在江南的一个小镇上,刚好雄伟的苏通大桥从我们...
    小月半脚阅读 357评论 5 5
  • 如我对一杯咖啡的反应 后知后觉 思来想去 编不出我们有交集的谎言来欺骗自己 我们就这样吧 不再靠近了。
    久等阅读 164评论 0 0