目录
1.Binder 有什么优势
性能方面
共享内存 :0 次数据拷贝
Binder: 1 次数据拷贝
Socket/管道/消息队列 :2 次数据拷贝
稳定性方面
Binder:基于C/S架构,客户端(Client)有什么需求就丢给服务端(Server)去完成,架构清晰、职责明确又相互独立,自然稳定性更好。
共享内存:虽然无需拷贝,但是控制复杂,难以使用。
从稳定性的角度讲,Binder 机制是优于内存共享的。
安全性方面
传统的IPC没有任何的安全措施,完全是依赖上层协议来确保。
传统的 IPC 方法无法获得对方可靠的进程用户 ID/进程 UI(UID/PID),从而无法鉴
别对方身份。
传统的 IPC 只能由用户在数据包中填入 UID/PID,容易被恶意程序利用。
传统的 IPC 访问接入点是开放的,无法阻止恶意程序通过猜测接收方地址获得连接。
Binder 既支持实名 Binder,又支持匿名 Binder,安全性高。
2.Binder 是如何做到一次拷贝
主要是因为 Linux 是使用的虚拟内存寻址方式,它有如下特性:
用户空间的虚拟内存地址是映射到物理内存中的
对虚拟内存的读写实际上是对物理内存的读写,这个过程就是内存映射
这个内存映射过程是通过系统调用 mmap()来实现的
Binder 借助了内存映射的方法,在内核空间和用户空间的数据缓存区之间做
了一层内存映射 , 就相当于直接拷贝到了用户空间的数据缓存区 , 从而减少
了一次数据拷贝
3.Binder是如何跨进程的
Binder 驱动在内核空间创建一块缓存区,实现地址映射:将内核缓存区、用户空间映射到同一接收缓存区
发送进程通过系统调用(copy_from_user)将数据发送到内核缓存区。由于内核缓存区和接收进程用户空间存在映射关系,故相当于也发送了接收进程的用户空间,实现了跨进程通信。