iOS中Main App和Extensions之间通信

来源:互联网 发布:mac 终端查找文件夹 编辑:程序博客网 时间:2024/04/28 21:52

iOS中Main App和Extensions之间通信

本文主要介绍MMWormhole框架的使用, 该框架主要用来实现进程间的通信, 在iOS开发中我们经常需要app和extension之间进行数据通信,例如: app和widget之间的通信, 这时候我们就可以使用MMWormhole来实现.

基本原理

首先需要简单介绍一下app groups的概念,下面是一段简单的描述:

这是iOS8新开放的功能,在OS X上早就可用了。它主要用于同一group下的app共享同一份读写空间,以实现数据共享。
extension和containing app共同读写一份数据是很合理的需求,比如系统的股市应用,widget和app中都需要展示几个公司的股票数据,这就可以通过App Groups实现。

其实MMWormhole也是基于这个实现的, 这种通信模式其实跟android中的content provider的形式很类似, 关于App Groups更深入的了解大家可以查阅相关资料, 这里不详细阐述了.

具体使用

这里是效果图:

这里写图片描述

具体的使用方法也很简单,大致分为以下几步:

1.初始化, 这里需要使用group id, 也就是前面提到的app group.

self.wormhole = [[MMWormhole alloc] initWithApplicationGroupIdentifier:@"group.com.mutualmobile.wormhole"                                               optionalDirectory:@"wormhole"];

2.消息接受方注册监听

[self.wormhole listenForMessageWithIdentifier:@"messageIdentifier"  listener:^(id messageObject) {    // Do Something}];

3.消息发送方发送消息

[self.wormhole passMessageObject:@{@"titleString" : title} identifier:@"messageIdentifier"];

基于以上三步,也就基本实现了消息通信, 而且还能够传递数据, 使用也非常方便.具体详细的介绍,大家可以去github官网查看.

总结

其实, MMWormhole采用的是文件固化的方式,将具体的数据写入app group中,然后实现进程间的通信,同时它的底层是基于CFNotificationCenter这种系统级消息机制实现的,来实现进程间的通信服务.

项目地址:https://github.com/mutualmobile/MMWormhole

1 0
原创粉丝点击