iPhone开发之—守护进程和前台进程之间的通信
2012-10-08 17:23
369 查看
最近项目中要实现iphone手机的pc端远程控制,特别研究了一下,守护进程与前台进程消息传递的问题
一种是基于文件的模式
也就是在后台程序中设定一个定时器,定时读取用户交互信息的文件,这样实现的通信机制,虽然也解决了问题,但是,缺陷是需要一直跑一个定时器来查询前台是否传递信息过来了
另一种是使用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);
还有一种信号量的机制,本人也还没研究,但是看见过别的程序中有使用过,应该也是可以的!!
一种是基于文件的模式
也就是在后台程序中设定一个定时器,定时读取用户交互信息的文件,这样实现的通信机制,虽然也解决了问题,但是,缺陷是需要一直跑一个定时器来查询前台是否传递信息过来了
另一种是使用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);
还有一种信号量的机制,本人也还没研究,但是看见过别的程序中有使用过,应该也是可以的!!
相关文章推荐
- iPhone开发之—守护进程和前台进程之间的通信
- iPhone开发之—守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- iPhone开发之—守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- iphone守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- iphone守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- iphone守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- iphone守护进程和前台进程之间的通信-前台应用发信息给后台的守护进程
- Activity与Service通信(不同进程之间)
- chrome插件开发:content、background和popup三者之间的通信
- 【原创】《Linux高级程序设计》杨宗德著 - 进程管理与程序开发 - 信号量通信机制 分类: Linux --- 应用程序设计 2014-11-13 11:08 70人阅读 评论(0) 收藏
- C++和C#进程之间通过命名管道通信(上)
- Linux下进程之间的通信
- 同一个父进程的多个子进程之间的通信
- C++和C#进程之间通过命名管道通信(上)
- 线程之间进程之间的通信方式及其代码实现
- 进程之间的通信--套接字(网络部分)
- delphi 与 C++ 进程之间的命名管道通信
- 进程控制开发[fork() exec exit _exit wait waitpid 守护进程]
- AngularJS开发教程之控制器之间的通信方法分析
- [置顶] Android开发知识(三)Android进程间Binder通信机制的源码分析(上)