进程间通信IPC与Binder机制原理

1, Intent隐式意图携带数据

2, AIDL(Binder)

3, 广播BroadCast

4, 内容提供者ContentProvider

5,Messager(内部通过binder实现)

6,文件共享

7,socket

 

--------------------------------------------Binder底层原理----------------------------------------

Binder是一种进程间通信机制,它提供远程过程调用(RPC)功能; Binder作为一个类,它能和不同进程之间进行通信。从英文字面上意思看,Binder具有粘结剂的意思,那么它把什么东西粘结在一起呢?在Android系统的Binder机制中,由一些系统组件组成,分别是Client、Server、Service Manager和Binder驱动程序,其中Client、Server和Service Manager运行在用户空间,Binder驱动程序运行内核空间。Binder就是一种把这四个组件粘合在一起的粘结剂了,其中,核心组件便是Binder驱动程序了,Service Manager提供了辅助管理的功能,Client和Server正是在Binder驱动和Service Manager提供的基础设施上,进行Client-Server之间的通信。Service Manager和Binder驱动已经在Android平台中实现好,开发者只要按照规范实现自己的Client和Server组件就可以了。 

总结一下,Android系统Binder机制中的四个组件Client、Server、Service Manager和Binder驱动程序的关系如下图所示:

       

        1. Client、Server和Service Manager实现在用户空间中,Binder驱动程序实现在内核空间中

        2. Binder驱动程序和Service Manager在Android平台中已经实现,开发者只需要在用户空间实现自己的Client和Server

        3. Binder驱动提供设备文件/dev/binder与用户空间交互,Client、Server和Service Manager通过open和ioctl文件操作函数与Binder驱动程序进行通信

        4. Client和Server之间的进程间通信通过Binder驱动程序间接实现

        5. Service Manager是一个守护进程,用来管理Server,并向Client提供查询Server接口的能力

        至此,对Binder机制总算是有了一个感性的认识。

 

RPC代码是远程调用的方法名,RPC数据是方法的参数. handle是对应服务向ServiceManager注册的索引值. binder协议规定了是发送还是接收数据以及数据格式等内容. 

举例:

TelephonyManager tm = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);

RPC代码是getSystemService, RPC数据则是Context.TELEPHONY_SERVICE,  rpc层生成这些数据,  ipc层将这些数据与handle,binder协议打包并经binder驱动传输到服务端,服务端解析这些数据从而完成进程间的通信.

 

posted @ 2016-03-31 09:29  tiger168  阅读(758)  评论(0编辑  收藏  举报