Binder 系统 最重要的两个核心是 IPC 和 RPC ;
IPC ( Inter-Process Communication ) 进程间通信 : 数据在 不同的进程 之间传递 ; 如 : 进程 A 发送数据到进程 B ;
RPC ( Remote Procedure Call ) 远程过程调用 : A 进程通过 IPC 发送数据到 B 进程 , B 进程调用自己本地的相关逻辑 , A 进程通过 RPC 调用了 B 进程的代码 ;
RPC 是在 IPC 基础上进行的封装 , IPC 负责数据的跨进程传输 ;
数据传输需要由
个要素组成 , 数据源 ( 进程 A ) , 目的地 ( 进程 B ) , 数据 ;
IPC 目的端进程标识 : 那么如果要实现 IPC 跨进程通信 , 源端 进程 A 如何 标识 目的端 进程 B , 进程 A 应该向哪个进程发送数据 , 如何进行标识 ;
服务注册与查询 : 进程 B 向 ServiceManager 注册服务 , 进程 A 从 ServiceManager 查询进程 B 注册的服务 , 得到一个 Handle , 该 Handle 指向进程 B ;
在 Android 系统中 , 进程 A 就是 Client 客户端 , 进程 B 就是 Server 服务端 ,
Client 客户端 如何 标记 Server 服务端 , 这里引入 ServiceManager , 这三者之间的通信 , 通过 Binder 驱动 实现 ;
如下图所示 :
RPC ( Remote Procedure Call ) 远程过程调用 可以理解为 调用其它某个进程的函数 ;
RPC 涉及到的函数相关问题 : 这里有涉及到识别问题 , 如何 标识 远程调用目的进程的某个 函数 , 给函数传递哪些 参数 , 该函数如何返回 返回值 ;
标识函数 : 需要 Client 客户端 向 Server 服务端 发送要调用的 函数的编号 ;
传递参数 : 远程过程调用 的参数放在 IPC 数据中的缓冲区 中 ;
返回返回值 : 函数执行完毕后 , Server 服务端需要将返回值通过 IPC 发送给 Client 客户端 , 该返回值也是存放在 IPC 数据缓冲区 中传递回去 ;