Binder机制---IPC、RPC的过程,69个经典Android面试题和答案详解

一个拥有独立空间的进程如何向另一个进程传递数据呢?显然要通过两个进程共享的内核空间。从内核的角度看,进程不过是一个作业单位,虽然各个进程的用户空间相对独立,但是运行在内核空间中的任务数据、代码都是彼此共享的。 Binder机制---IPC、RPC的过程,69个经典Android面试题和答案详解_第1张图片 Linux本身就提供IPC工具,用于两个进程通过内核进行通信。Android中的binder功能更丰富,不仅可以进行IPC通信,还可以用来调用另一个进程的函数,即支持进程之间的RPC操作。 IPC:(Inter Process Communication)跨进程通信
RPC: (Reomote Procedure Call) 远程过程调用

Binder通信的过程中,分为两个进程Client和Service。Client和Service是相对的,谁发送消息,谁就是Client,谁接收消息,谁就是Service

进程之间是如何远程调用函数的呢?

Binder机制---IPC、RPC的过程,69个经典Android面试题和答案详解_第2张图片 客户端要通过IPC调用实现Server端foo函数的调用,就需要将Binder IPC数据传递给Server端,传递的过程需要Binder Driver充当中间人,接收来自客户端的IPC数据,而后传递给Server端。 IPC数据包含函数调用相关的内容:服务号、RPC数据和代码、binder协议三部分构成。

    你可能感兴趣的:(程序员,面试,移动开发,android)