美文网首页iOS开发
利用runtime反射机制解耦

利用runtime反射机制解耦

作者: 12345qwert | 来源:发表于2018-12-21 21:50 被阅读8次

前言

本文参考了微信读书团队的文章,学习了runtime反射机制的强大。具体的demo工程

学习过程1

A和B想要通信(比如A想要B模块的某个能力),都是通过中间件进行调度,这里起名叫Mediator。Mediator并不会将A和B的.h文件import进来,怎么做到的呢?就是通过runtime的反射机制。如果B想要A模块的某个能力,A只需要在Mediator中开放这样一个能力接口,供B通过Mediator进行调用。
具体代码参考如下:

//  main.m
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import <Foundation/Foundation.h>
#import "B.h"

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        // insert code here...
        B *b = [[B alloc] init];
        [b print];
    }
    return 0;
}
//  Mediator.h
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import <Foundation/Foundation.h>

NS_ASSUME_NONNULL_BEGIN

@interface Mediator : NSObject

- (void)printInBFromA:(NSString *)str;

@end

NS_ASSUME_NONNULL_END
//  Mediator.m
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import "Mediator.h"

@implementation Mediator

- (void)printInBFromA:(NSString *)str {
    Class classA = NSClassFromString(@"A");
    id aInstance = [[classA alloc] init];
    [aInstance performSelector:NSSelectorFromString(@"print:") withObject:str];
}

@end
//  A.h
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import <Foundation/Foundation.h>

NS_ASSUME_NONNULL_BEGIN

@interface A : NSObject


@end

NS_ASSUME_NONNULL_END
//  A.m
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import "A.h"

@implementation A

- (void)print:(NSString *)str {
    NSLog(@"------> %@",str);
}

@end
//  B.h
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import <Foundation/Foundation.h>

NS_ASSUME_NONNULL_BEGIN

@interface B : NSObject

- (void)print;

@end

NS_ASSUME_NONNULL_END
//  B.m
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/21.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import "B.h"
#import "Mediator.h"

@implementation B

- (void)print {
    Mediator *mediator = [[Mediator alloc] init];
    [mediator printInBFromA:@"hello"];
}

@end

学习过程2

如果说需要传入的参数不止2个(performSelector最多只支持两个),我们可以通过dict的形式进行传参数。

学习过程3

如果说Mediator需要提供的接口实在太多,我们可以通过Category,让各自提供方的模块制作Mediator的Category。Category文件依旧放在Mediator所在的模块中。

//  Mediator+A.h
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/22.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import "Mediator.h"

NS_ASSUME_NONNULL_BEGIN

@interface Mediator (A)

- (void)printInDFromA:(NSString *)bookId count:(NSInteger)bookCount price:(CGFloat)bookPrice;

@end

NS_ASSUME_NONNULL_END
//  Mediator+A.m
//  MediatorProject
//
//  Created by hushunfeng on 2018/12/22.
//  Copyright © 2018 cmcc. All rights reserved.
//

#import "Mediator+A.h"

@implementation Mediator (A)

- (void)printInDFromA:(NSString *)bookId count:(NSInteger)bookCount price:(CGFloat)bookPrice {
    Class classA = NSClassFromString(@"A");
    id aInstance = [[classA alloc] init];
    NSDictionary *params = @{@"bookId":bookId,@"bookCount":@(bookCount),@"bookPrice":@(bookPrice)};
    [aInstance performSelector:NSSelectorFromString(@"printBook:") withObject:params];

}


@end

过程4

Mediator 每一个方法里都要写 runtime 方法,格式是确定的,这是可以抽取出来的。在Mediator中添加如下方法:

- (void)performTarget:(NSString *)targetName action:(NSString *)actionName params:(NSDictionary *)params {
    Class target = NSClassFromString(targetName);
    id targetInstance = [[target alloc] init];
    [targetInstance performSelector:NSSelectorFromString(actionName) withObject:params];
}

相关文章

  • 利用runtime反射机制解耦

    前言 本文参考了微信读书团队的文章,学习了runtime反射机制的强大。具体的demo工程 学习过程1 A和B想要...

  • Runtime3 - isKindOfClass、isMembe

    OC的反射机制:反射最主要的目的是解耦。isMemberOfClass:判断是否是某一个类isKindOfClas...

  • Android组件化架构 - 4. 动态创建 & 反射机制

    Android 组件化中使用动态创建的作用是解耦; 1. 反射机制 反射有两个作用:1.反编译:.class->....

  • 反射

    将类的各个组成部分封装为其他对象,就是反射机制 反射的好处: 在程序的运行过程中,操作这些对象 可以解耦,提高程序...

  • Java反射机制

    摘要:在Java开发中,反射的应用尤其的广泛,很多优秀的框架都会充分利用Java的反射来对程序进行解耦,包括很多的...

  • runtime之反射机制

    以下是JsonModel核心思想,利用runtime的反射机制,获取对应的属性名称和类型,再将对应的json序列化...

  • 2018-03-07 Dagger2 解耦 简单使用

    解耦方式 1、利用配置文件,使用反射获取到需要加载的对象。 2、设计模式:单例、工厂、观察者....等 什么是Da...

  • iOS的一点架构分享

    前言 其实以前写过这么一片类似的文章链接,利用字符串+runtime能做到命名域级别的解耦,其实这种做法很极端,编...

  • 用静态工厂来封装retrofit

    用静态工厂来封装retrofit 利用反射机制和静态工厂模式,对retrofit进行简单的封装 利用反射机制,动态...

  • Java反射

    Java反射 概述 Java反射机制可以让我们在编译期(Compile Time)之外的运行期(Runtime)检...

网友评论

    本文标题:利用runtime反射机制解耦

    本文链接:https://www.haomeiwen.com/subject/zdtbkqtx.html