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

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

文章目录

一、Binder 系统两个核心

二、IPC 进程间通信

三、RPC 远程过程调用





一、Binder 系统两个核心


Binder 系统 最重要的两个核心是 IPC 和 RPC ;


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


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



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






二、IPC 进程间通信


数据传输需要由 3 33 个要素组成 , 数据源 ( 进程 A ) , 目的地 ( 进程 B ) , 数据 ;



IPC 目的端进程标识 : 那么如果要实现 IPC 跨进程通信 , 源端 进程 A 如何 标识 目的端 进程 B , 进程 A 应该向哪个进程发送数据 , 如何进行标识 ;


服务注册与查询 : 进程 B 向 ServiceManager 注册服务 , 进程 A 从 ServiceManager 查询进程 B 注册的服务 , 得到一个 Handle , 该 Handle 指向进程 B ;



在 Android 系统中 , 进程 A 就是 Client 客户端 , 进程 B 就是 Server 服务端 ,


Client 客户端 如何 标记 Server 服务端 , 这里引入 ServiceManager , 这三者之间的通信 , 通过 Binder 驱动 实现 ;


如下图所示 :



image.png





三、RPC 远程过程调用


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



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


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


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


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


目录
相关文章
|
1月前
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第7天】麒麟系统mate-indicators进程占用内存过高问题解决
176 2
|
3月前
|
负载均衡 网络协议 小程序
SpringCloud远程调用为啥要采用HTTP,而不是RPC?
【8月更文挑战第28天】在微服务架构日益盛行的今天,SpringCloud凭借其强大的生态系统和灵活的集成能力,成为了众多企业构建微服务系统的首选框架。在微服务之间的远程调用中,一个常见的问题是选择HTTP还是RPC(远程过程调用)作为通信协议。本文将深入探讨SpringCloud为何更倾向于采用HTTP而非RPC进行远程调用。
330 5
|
2月前
|
监控
MASM32写的免费软件“ProcView/系统进程监控” V1.4.4003 说明和下载
MASM32写的免费软件“ProcView/系统进程监控” V1.4.4003 说明和下载
|
1月前
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第5天】麒麟系统mate-indicators进程占用内存过高问题解决
133 0
|
1月前
|
负载均衡 Java 开发者
Spring Cloud 远程调用:为何选择 HTTP 而非 RPC?
【10月更文挑战第1天】在微服务架构中,远程服务调用是一个核心环节。面对HTTP和RPC(Remote Procedure Call,远程过程调用)这两种通信协议,Spring Cloud 选择了HTTP作为其主要通信手段。本文将深入探讨Spring Cloud选择HTTP而非RPC的原因,以及这一选择在实际工作中的优势。
83 0
|
2月前
|
监控 Ubuntu API
Python脚本监控Ubuntu系统进程内存的实现方式
通过这种方法,我们可以很容易地监控Ubuntu系统中进程的内存使用情况,对于性能分析和资源管理具有很大的帮助。这只是 `psutil`库功能的冰山一角,`psutil`还能够提供更多关于系统和进程的详细信息,强烈推荐进一步探索这个强大的库。
43 1
|
2月前
|
Java Android开发 数据安全/隐私保护
Android中多进程通信有几种方式?需要注意哪些问题?
本文介绍了Android中的多进程通信(IPC),探讨了IPC的重要性及其实现方式,如Intent、Binder、AIDL等,并通过一个使用Binder机制的示例详细说明了其实现过程。
316 4
|
2月前
|
安全 开发者 Python
揭秘Python IPC:进程间的秘密对话,让你的系统编程更上一层楼
【9月更文挑战第8天】在系统编程中,进程间通信(IPC)是实现多进程协作的关键技术。IPC机制如管道、队列、共享内存和套接字,使进程能在独立内存空间中共享信息,提升系统并发性和灵活性。Python提供了丰富的IPC工具,如`multiprocessing.Pipe()`和`multiprocessing.Queue()`,简化了进程间通信的实现。本文将从理论到实践,详细介绍各种IPC机制的特点和应用场景,帮助开发者构建高效、可靠的多进程应用。掌握Python IPC,让系统编程更加得心应手。
32 4
|
2月前
|
监控 API
【原创】用Delphi编写系统进程监控程序
【原创】用Delphi编写系统进程监控程序
|
3月前
|
API Android开发
Android P 性能优化:创建APP进程白名单,杀死白名单之外的进程
本文介绍了在Android P系统中通过创建应用进程白名单并杀死白名单之外的进程来优化性能的方法,包括设置权限、获取运行中的APP列表、配置白名单以及在应用启动时杀死非白名单进程的代码实现。
63 1

相关实验场景

更多