博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iphone守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
阅读量:4110 次
发布时间:2019-05-25

本文共 1229 字,大约阅读时间需要 4 分钟。

当我们创建基于mobilesubstrate的应用时,通常都是一些前后台程序,典型的比如苹果皮等,这个需要前台程序法信息到后台进程中,这里有两种方式

一种是基于文件的模式

也就是在后台程序中设定一个定时器,定时读取用户交互信息的文件,这样实现的通信机制,虽然也解决了问题,但是,缺陷是需要一直跑一个定时器来查询前台是否传递信息过来了

还有一种是使用CFMessagePortRef

典型的如下模式:

#define APP_ID "yohunl.support.mach.port"

#define MACH_PORT_NAME APP_ID

 

在后台进程中创建一个用于进程通讯的 CFMessagePortRef

CFMessagePortRef local = CFMessagePortCreateLocal(kCFAllocatorDefault, CFSTR(MACH_PORT_NAME), mouseCallBack, NULL, NULL);

  CFRunLoopSourceRef source = CFMessagePortCreateRunLoopSource(kCFAllocatorDefault, local, 0);
CFRunLoopAddSource(CFRunLoopGetCurrent(), source, kCFRunLoopCommonModes);

 

其中的mouseCallback是回调函数,其声明是

CFDataRef mouseCallBack(CFMessagePortRef local, SInt32 msgid, CFDataRef cfData, void *info);

 

 

在前台进程中使用发送消息的模式

CFMessagePortRef bRemote = CFMessagePortCreateRemote(kCFAllocatorDefault, CFSTR(MACH_PORT_NAME));

// tell thread b to print his name
char message[255]="lingdaiping,yohunl";
CFDataRef data;
data = CFDataCreate(NULL, (UInt8 *)message, strlen(message)+1);
(void)CFMessagePortSendRequest(bRemote, CFSTR(MACH_PORT_NAME), data, 0.0, 0.0, NULL, NULL);
CFRelease(data);
CFRelease(bRemote);

 

 

 

 

还有一种信号量的机制,本人也还没研究,但是看见过别的程序中有使用过,应该也是可以的!!

 

 

 

 

 

最近又发现了一种方式:CPDistributedMessagingCenter方式,这个貌似就是上面的方法2的封装,不过这只是个人推测而已!!

转载地址:http://jnosi.baihongyu.com/

你可能感兴趣的文章
在osg场景中使用GLSL语言——一个例子
查看>>
ZendStudio代码提示巨慢的一个原因
查看>>
Linux上卸载ZendStudio
查看>>
iOS 操作系统被曝无线网络命名bug 导致 iPhone无法连接无线网络
查看>>
好气!等一年,这个iCloud 账户漏洞竟只值$1.8万?!说好的$35万呢???
查看>>
Linux 应用市场易受RCE和供应链攻击,多个0day未修复
查看>>
可蠕虫 DarkRadiation 勒索软件瞄准 Linux 和 Docker 实例
查看>>
Windows DWrite 组件 RCE 漏洞 (CVE-2021-24093) 分析
查看>>
数百万戴尔设备遭 BIOSConnect 代码执行漏洞影响
查看>>
Atlassian 域名被曝一次点击账户接管漏洞 可导致供应链攻击
查看>>
软件物料清单 (SBOM):从透明度理念到代码落地
查看>>
合勤科技称企业防火墙和VPN设备遭复杂攻击
查看>>
Fortinet 防火墙受高危漏洞影响,可遭远程攻击
查看>>
微软称 SolarWinds 黑客还在继续攻击 IT 企业
查看>>
老旧漏洞不修复,西部数据存储设备数据遭擦除
查看>>
微软 Edge bug 导致黑客窃取用户在任意站点的机密信息,颁发2万美元奖金
查看>>
Phoenix Contact 多款工业产品被曝多个高危漏洞
查看>>
什么鬼?我能通过依赖混淆攻击在 Halo 游戏服务器中执行命令,微软不 care?!...
查看>>
谷歌 Compute Engine 的虚拟机曝0day未修复,可遭接管
查看>>
美国特勤局发布十大网络通缉犯名单
查看>>