iOS组件化(二)模块生命周期独立化

虽然我们重构了AppDelegate,给AppDelegate瘦身,但是还是会有各模块耦合在一起的情况。所以,组件化必须要考虑到各模块的生命周期独立化,也就是AppDelegate中的生命周期方法要让每个模块都单独管理一份

豆瓣FRDModuleManager

FRDModuleManager

豆瓣的方案是使用一个.plist文件配置要使用 APP 生命周期的类,再使用一个FRDModuleManager负责调用这些类。

FRDModuleManager 是遵循<UIApplicationDelegate, UNUserNotificationCenterDelegate>协议的。如下:

interface FRDModuleManager : NSObject<UIApplicationDelegate, UNUserNotificationCenterDelegate>

+ (instancetype)sharedInstance;

- (void)loadModulesWithPlistFile:(NSString *)plistFile;

- (NSArray<id<FRDModule>> *)allModules;

end

使用:在 AppDelegate中使用FRDModuleManager加载.plist文件中的类,并在 AppDelegate 的生命周期方法中调用 FRDModuleManager 的方法。示例如下:

- (BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

  NSString* plistPath = [[NSBundle mainBundle] pathForResource:@"ModulesRegister" ofType:@"plist"];

  FRDModuleManager *manager = [FRDModuleManager sharedInstance];
  [manager loadModulesWithPlistFile:plistPath];

  [manager application:application willFinishLaunchingWithOptions:launchOptions];

  return YES;
}
...

缺点:需要引入FRDModuleManager.h,而且每个方法都要调用FRDModuleManager

实际应用中,每个已开发的工程都是有AppDelegate.m文件的,而且如果 AppDelegate 使用了扩展,还需要在扩展中调用,FRDModuleManager 的使用就散落了,也容易遗漏。

支付宝mPaaS

通过修改 main.m 函数的实现,mPaaS 框架使用自己的 ClientDelegate 类接管了 UIApplicationDelegate 中各种 App 生命周期。mPaaS 框架接入之后,ClientDelegate 完全替代了一般工程中的 AppDelegate 的角色,从而实现了整个应用的生命周期都是由框架进行管理。

int main(int argc, char * argv[]) {
    @autoreleasepool {
        // Now use mPaaS framework
        return UIApplicationMain(argc, argv, @"Application", @"ClientDelegate"); 
    }
}

我们

APPDelegateClient

图中,在.plist中配置了每个模块独立管理 App 生命周期的类名。

然后,学习了mPaaS的思路,在main.m中改变 App 启动接收者为LCClientDelegate

int main(int argc, char * argv[]) {
    @autoreleasepool {
        return UIApplicationMain(argc, argv, nil, @"LCClientDelegate");
    }
}

LCClientDelegate同样需要遵循<UIApplicationDelegate, UNUserNotificationCenterDelegate>协议,接管了 App 声明周期以后,把接收到的 App 生命周期方法利用消息转发.plist中配置的所有接受者。

优点:不需要改变原来的AppDelegate.m文件,将它也配置在.plist文件中即可。

但是

最终的方案的确很好,毕竟mPaaS可是收费的,借鉴它的思想自然不错。

兴冲冲的学习了以后,加入到项目中没多久,就发现一般项目中用不到这么大的需求😭。主要还是因为 AppDelegate 本身就不需要很大的逻辑,我们之前的逻辑很多是不对的,一个好的项目结构不需要如此。例如:通知需求,也可以轻松使用中间件化解耦合。

它适合的场景就像mPaaS中提到的微应用概念,例如支付宝和微信的小程序。而我们只不过是一个项目的不同模块而已。

那你会想如果使用的话最多不过是大材小用?因为利用的是NSProxy消息转发的方案,常使用 APPDelegate 的 window 属性都要走在里面不断的转发,就很烦了。。。

建议:最终建议如果类似支付宝和微信的的小程序概念,也就是当前只运行一个或几个程序(不是全部),在原来的.plist注册上优化只转发给正在使用的微应用。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容

  • 关于组件化 网上组件化的文章很多。很多文章一提到组件化,就会说解耦,一说到解耦就会说路由或者runtime。好像组...
    朱大爷12138阅读 20,803评论 17 130
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,094评论 1 32
  • 1.感恩感谢情人节礼物。今天最大的快心莫过于30天感恩能量训练营结业证书,让感恩成为生活的习惯!今天同事给女儿送了...
    晶晶有味阅读 355评论 0 0
  • 我仍然认为, 人类的卑鄙, 比我所认知的更加深重
    醉卧人间阅读 130评论 0 0
  • 奶奶不在的这些天檬檬特别黏爸爸,几乎从早到晚缠着爸爸抱她,去外面玩,连爸爸上厕所、换鞋、做饭都要求爸爸抱着,妈妈想...
    青鸟_01阅读 241评论 0 0