zoukankan      html  css  js  c++  java
  • 进程间通信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驱动传输到服务端,服务端解析这些数据从而完成进程间的通信.

  • 相关阅读:
    uboot的启动过程-FDT
    pat练习
    也不知道 为什么没通过 -------------存疑 ---延后解决
    刚认识--博客园
    MapReduce报错Exception in thread "main" java.lang.UnsatisfiedLinkError: org.apache.hadoop.io.nativeio
    Hadoop 学习笔记(十)HDFS 之 集群安全模式 & DateaNode
    Hadoop 学习笔记(九)HDFS 之 NameNode & SecondaryNameNode
    sqlldr 报错:Field in data file exceeds maximum length 解决方法
    Hadoop 学习笔记(八)HDFS 数据的读写
    Hadoop 学习笔记(七)HDFS 客户端操作(下)
  • 原文地址:https://www.cnblogs.com/wytiger/p/5339937.html
Copyright © 2011-2022 走看看