Messenger与AIDL的区别

大家都知道目前安卓的各种第三方推送服务都是采用多路复用的技术,即多个app共享一个后台service,一条长连接处理多个app的推送任务。

那么移动的aoe推送也是采用这种方案,在这里分享下研究结果。

进程间通信,一般有两种方式AIDL和Messenger。


1. Messenger是对AIDL的一种封装,开发的时候不用再写.aidl文件。

结合我自身的使用,因为不用去写.aidl文件,相比起来,Messenger使用起来十分简单。但前面也说了,Messenger本质上也是AIDL,故在底层进程间通信这一块,两者的效率应该是一样的。


2. service端,Messenger处理client端的请求是单线程的,而AIDL是多线程的。

使用AIDL的时候,service端每收到一个client端的请求时,就会启动一个线程去执行相应的操作。而Messenger,service收到的请求是放在Handler的MessageQueue里面,Handler大家都用过,它需要绑定一个Thread,然后通过Looper不断循环取出message执行相关操作,这个过程是同步执行的。但是你也可以不直接处理请求,而是开启线程或者使用线程池,这样也可以实现异步。


3. client端,使用AIDL获取返回值是同步的,而Messenger是异步的。

Messenger只提供了一个方法进行进程间通信,就是send(Message msg)方法,发送的是一个Message,没有返回值,要拿到返回值,需要把client的Messenger作为msg.replyTo参数传递过去,service端处理完之后,在调用客户端的Messenger的send(Message msg)方法把返回值传递回client,这个过程是异步的,而AIDL你可以自己指定方法,指定返回值,它获取返回值是同步的。


你可能感兴趣的:(android)