【Android Binder 系统】一、Binder 系统核心 ( IPC 进程间通信 | RPC 远程调用 )

举报
韩曙亮 发表于 2022/01/11 01:17:06 2022/01/11
【摘要】 文章目录 一、Binder 系统两个核心二、IPC 进程间通信三、RPC 远程过程调用 一、Binder 系统两个核心 Binder 系统 最重要的两个核心是 IP...





一、Binder 系统两个核心



Binder 系统 最重要的两个核心是 IPCRPC ;

IPC ( Inter-Process Communication ) 进程间通信 : 数据在 不同的进程 之间传递 ; 如 : 进程 A 发送数据到进程 B ;

RPC ( Remote Procedure Call ) 远程过程调用 : A 进程通过 IPC 发送数据到 B 进程 , B 进程调用自己本地的相关逻辑 , A 进程通过 RPC 调用了 B 进程的代码 ;


RPC 是在 IPC 基础上进行的封装 , IPC 负责数据的跨进程传输 ;





二、IPC 进程间通信



数据传输需要由 3 3 3 个要素组成 , 数据源 ( 进程 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 远程过程调用



RPC ( Remote Procedure Call ) 远程过程调用 可以理解为 调用其它某个进程的函数 ;


RPC 涉及到的函数相关问题 : 这里有涉及到识别问题 , 如何 标识 远程调用目的进程的某个 函数 , 给函数传递哪些 参数 , 该函数如何返回 返回值 ;

标识函数 : 需要 Client 客户端 向 Server 服务端 发送要调用的 函数的编号 ;

传递参数 : 远程过程调用 的参数放在 IPC 数据中的缓冲区 中 ;

返回返回值 : 函数执行完毕后 , Server 服务端需要将返回值通过 IPC 发送给 Client 客户端 , 该返回值也是存放在 IPC 数据缓冲区 中传递回去 ;

文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。

原文链接:hanshuliang.blog.csdn.net/article/details/112691834

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

举报
请填写举报理由
0/200