一个拥有独立空间的进程如何向另一个进程传递数据呢?显然要通过两个进程共享的内核空间。从内核的角度看,进程不过是一个作业单位,虽然各个进程的用户空间相对独立,但是运行在内核空间中的任务数据、代码都是彼此共享的。
Linux本身就提供IPC工具,用于两个进程通过内核进行通信。Android中的binder功能更丰富,不仅可以进行IPC通信,还可以用来调用另一个进程的函数,即支持进程之间的RPC操作。 IPC:(Inter Process Communication)跨进程通信
RPC: (Reomote Procedure Call) 远程过程调用
Binder通信的过程中,分为两个进程Client和Service。Client和Service是相对的,谁发送消息,谁就是Client,谁接收消息,谁就是Service
进程之间是如何远程调用函数的呢?
客户端要通过IPC调用实现Server端foo函数的调用,就需要将Binder IPC数据传递给Server端,传递的过程需要Binder Driver充当中间人,接收来自客户端的IPC数据,而后传递给Server端。 IPC数据包含函数调用相关的内容:服务号、RPC数据和代码、binder协议三部分构成。
- 服务号(Handle):用来区分不同的服务,Driver层通过handle值确定将ipc数据传递给到哪个服务中,也就是目标服务的编号
- RPC数据:用来指定指定服务中将调用的函数(包括函数名和参数)</
Android Binder机制详解:IPC与RPC实践

本文深入探讨了Android中的Binder机制,解释了如何实现进程间的远程函数调用。详细介绍了Context Manager(ServiceManager)的注册、检索和调用流程,并分析了Binder Driver的关键函数,如binder_open。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



