前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Android Binder 系统】一、Binder 系统核心 ( IPC 进程间通信 | RPC 远程调用 )

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

作者头像
韩曙亮
发布2023-03-28 20:54:23
7750
发布2023-03-28 20:54:23
举报
文章被收录于专栏:韩曙亮的移动开发专栏

文章目录

一、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

个要素组成 , 数据源 ( 进程 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 数据缓冲区 中传递回去 ;

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-01-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、Binder 系统两个核心
  • 二、IPC 进程间通信
  • 三、RPC 远程过程调用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档