【Binder 机制】进程通信-正常情况 | 进程通信- mmap 内存映射 | Binder 机制重要组件

简介: 【Binder 机制】进程通信-正常情况 | 进程通信- mmap 内存映射 | Binder 机制重要组件

文章目录

一、进程通信-正常情况 ( 两次拷贝 )

二、进程通信- mmap 内存映射 ( 一次拷贝 )

三、Binder 机制重要组件 ( Client 客户端 、Server 服务端、Service Manager、Binder 驱动 )





一、进程通信-正常情况 ( 两次拷贝 )


Binder 通信机制 依赖于 共享的 内核空间 ;


正常情况下 , 进行进程间的通信 , 需要进行如下操作 : 进行 2 22 次数据拷贝 , 用户空间 -> 内核空间 -> 用户空间 ;


进程 B 发送消息给进程 A , 先将数据 从 进程 A 的 用户空间 缓冲区 写到 内核空间 缓冲区中 , 然后将数据从 内核空间 缓冲区 写到 进程 A 的 用户空间 缓冲区 中 ;


image.png






二、进程通信- mmap 内存映射 ( 一次拷贝 )


Binder 可以只进行 一次拷贝 , 就可以完成跨进程通信 , 该依次拷贝是基于 内存映射 完成的 ;


内存映射 就是 基于 Memory Map 函数 mmap 进行的 ;


参考零拷贝原理 【Netty】mmap 和 sendFile 零拷贝原理 博客 ;


在 进程A 内存中 , 没有在自己的 用户空间 内存中申请 通信的数据缓冲区 , 而是在 内核空间 中申请了一块 进程 A 的缓冲区 ,






三、Binder 机制重要组件 ( Client 客户端 、Server 服务端、Service Manager、Binder 驱动 )


Binder 机制是 C/S 架构的 , Client / Server , 客户端就是进程 , 服务器就是系统的服务 ;


Service Manager 运行在 用户空间 , 负责管理 Server 服务器的 注册服务 功能 ;


Service 服务 需要 先注册 , 客户端 才能获取该 Service 服务 ;



客户端 , 服务端 , Service Manger , 都可以通过 ioctl 调用 Binder 驱动 ;



下图是 Binder 机制中的 4 44 个重要组成部分 , Client 客户端 , Server 服务端 , Service Manager , Binder 驱动 ;


image.png


进程 A 与 进程 B 之间通信 , 先通过 ServiceManager 获取 Binder 驱动的代理 , 然后使用对应的服务 ;


AIDL ( Android Interface Definition Language ) 安卓接口定义语言 , 定义一些接口 , 让两个进程之间可以进行相互通信 ;



目录
相关文章
|
19天前
|
安全 Go 开发者
“不要通过共享内存来通信”——深入理解Golang并发模型与CSP理论
Golang 采用 CSP 理念,主张“通过通信共享内存”,以消息传递替代共享内存,避免数据竞争。其核心为 Goroutine 与 Channel:轻量协程并发执行,通道安全传递数据,将并发复杂性转为通信编排,提升程序清晰度与可维护性。
118 0
|
10月前
|
消息中间件 存储 网络协议
从零开始掌握进程间通信:管道、信号、消息队列、共享内存大揭秘
本文详细介绍了进程间通信(IPC)的六种主要方式:管道、信号、消息队列、共享内存、信号量和套接字。每种方式都有其特点和适用场景,如管道适用于父子进程间的通信,消息队列能传递结构化数据,共享内存提供高速数据交换,信号量用于同步控制,套接字支持跨网络通信。通过对比和分析,帮助读者理解并选择合适的IPC机制,以提高系统性能和可靠性。
1282 14
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第7天】麒麟系统mate-indicators进程占用内存过高问题解决
1312 2
|
9月前
|
消息中间件 Linux
Linux中的System V通信标准--共享内存、消息队列以及信号量
希望本文能帮助您更好地理解和应用System V IPC机制,构建高效的Linux应用程序。
346 48
|
11月前
|
运维 监控 Ubuntu
【运维】如何在Ubuntu中设置一个内存守护进程来确保内存不会溢出
通过设置内存守护进程,可以有效监控和管理系统内存使用情况,防止内存溢出带来的系统崩溃和服务中断。本文介绍了如何在Ubuntu中编写和配置内存守护脚本,并将其设置为systemd服务。通过这种方式,可以在内存使用超过设定阈值时自动采取措施,确保系统稳定运行。
399 4
|
11月前
|
C语言 开发者 内存技术
探索操作系统核心:从进程管理到内存分配
本文将深入探讨操作系统的两大核心功能——进程管理和内存分配。通过直观的代码示例,我们将了解如何在操作系统中实现这些基本功能,以及它们如何影响系统性能和稳定性。文章旨在为读者提供一个清晰的操作系统内部工作机制视角,同时强调理解和掌握这些概念对于任何软件开发人员的重要性。
|
11月前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。
148 4
|
12月前
|
算法 调度 开发者
深入理解操作系统:从进程管理到内存分配
本文旨在为读者提供一个深入浅出的操作系统知识之旅,从进程管理的基础概念出发,探索内存分配的策略与技巧。我们将通过实际代码示例,揭示操作系统背后的逻辑与奥秘,帮助读者构建起对操作系统工作原理的直观理解。文章不仅涵盖理论知识,还提供实践操作的指导,使读者能够将抽象的概念转化为具体的技能。无论你是初学者还是有一定基础的开发者,都能在这篇文章中找到有价值的信息和启发。
|
12月前
|
算法 调度 C++
深入理解操作系统:从进程管理到内存分配
【10月更文挑战第42天】本文将带你进入操作系统的神秘世界,探索其核心概念和关键技术。我们将从进程管理开始,了解操作系统如何协调和管理多个程序的运行;然后,我们将深入研究内存分配,看看操作系统如何有效地分配和管理计算机的内存资源。通过这篇文章,你将获得对操作系统工作原理的深入理解,并学会如何编写高效的代码来利用这些原理。
|
消息中间件 存储 Linux

热门文章

最新文章