一、概述

Android系统中涉及到多进程通信底层都是依赖Binder IPC机制。例如当进程A中的Activity想要向进程B的Service通信,这就需要用到IPC。不仅如此,整个Android系统架构中,大量采用了Binder机制作为IPC(进程间通信)方案。

当然也存在其他的通信方式,如管道、消息队列、socket、内存共享、SystemV等。那为什么Android不使用这些原有的技术,而要开发一种新的Binder的进程间通信机制呢?

为什么要使用Binder?
性能方面

在移动设备上(性能受限制设备上,如省电),广泛的使用跨进程通信对通信机制的性能有严格的要求,Binder相比于传统的Socket方式,更高效。Binder数据拷贝只需要一次,而管道、消息队列、Socket都需要两次,共享内存一次都不需要拷贝,但实现方式又比较复杂。

安全方面
传统的进程通信方式对于通信双方身份并没有做出严格的验证,比如Socket通信的ip地址就是用户手动的填入的,很容易进行伪造,而Binder通信机制从协议本身就支持对通信双方做身份验证,大大提高了安全性。

二、Binder

要想了解Binder,首先先了解下Linux内核的基础知识:
(1)用户空间/内核空间:

用户空间指的是用户程序运行的空间,内核空间是Linux内核的运行空间,为了安全,它们是隔离的,即使用户的程序崩溃了,内核也是不受影响的。

(2)系统调用:
Linux将用户空间和内核空间隔离是有原因的,用户软件良莠不齐,要是它们乱搞,把系统搞坏了怎么办?因此对于某些特权操作必须放到内核中进行。
用户空间访问内核空间的唯一方式就是系统调用;通过这个统一入口接口,所有的资源访问都是在内核的控制下执行,以免导致用户程序对资源的越权访问,从而系统的安全和稳定性。

(3)Binder驱动:
通过系统调用,用户空间可以访问内核空间,那么如果一个用户空间想与另一个空间进行通信怎么办呢?很自然想到的是让操作系统内核添加支持;传统的Linux通信机制,比如Socket,管道等都是内和支持的;但是Binder并不是Linux内核的一部分,它是怎么做到访问内核空间的呢?
Linux的动态可加载内核模块(Loadable Kernel Mondule)解决了这个问题;模块是具有独立功能的程序,它只能被单独编译,不能独立运行。它在运行时被链接到内核作为内核的一部分在内核空间运行。这样,Android系统可以通过添加一个内核模块运行在内核空间,用户进程之间通过这个模块作为桥梁,就可以完成通信。
在Android系统中,这个运行在内核空间,负责各个用户进程通过Binder通信的内核模块叫做Binder驱动。

Binder

IPC原理
从进程角度来看IPC机制

每个Android的进程,只能运行在自己进程所拥有的的虚拟地址空间。对应一个4GB的虚拟地址空间,其中3GB是用户空间,1GB是内核空间,当然内核空间的大小是可以通过参数配置调整的。对于用户空间,不同进程之间彼此是不能共享的,而内核空间却是共享的。Client进程向Server进程通信。恰恰是利用进程间可共享的内核内存空间来完成底层通信工作的,Client端与Server端进程往往采用ioctl等方法跟内核空间的驱动进行交互。

Binder原理

Binder通信采用C/S结构,从组件视角来说,包含Client、Server、ServiceManager以及Binder驱动,其中ServiceManager用于管理系统中的各种服务,架构图如下所示:

Binder通信的四个角色:
Client进程:使用服务的进程。
Server进程:提供服务的进程。
ServiceManager进程:ServiceManager的作用是将字符形式的Binder名字转化成Client中对该Binder的引用,使得Client能够通过Binder名字获得对Server中Binder实体的引用。

Binder驱动:
驱动负责进程间Binder通信的建立,Binder在进程间的传递,Binder引用计数管理,数据包在进程间的传递与交互等一系列底层支持。

Binder运行机制:
图中Client/Server/ServiceManager之间的相互通信都是基于Binder机制。既然基于Binder机制通信,那么同样也是C/S结构。则图中的3大步骤都有相应的Client端与Service端。

注册服务:Server进程要先注册Service到 ServiceManager。该过程:Server是客户端,ServiceManager是服务端。

获取服务:Client进程使用某个Service前,须先向ServiceManager中获取相应的Service。该过程:Client是客户端,ServiceManaer是服务端。

使用服务:Client根据得到的Service信息建立与Service所在Service进程通信的道路,然后就可以直接与Service交互。该过程:Client是客户端,Server是服务端。

图中的Client,Server,ServiceManager之间交互都是虚线表示,是由于它们彼此之间不是直接交互的,而是通过与Binder驱动进行交互的,从而实现IPC通信方式。其中Binder驱动位于内核空间,Client,Server,ServiceManager位于用户空间。Binder驱动和Service Manager可以看做是Android平台的基础架构,而Client和Server是Android的应用层,开发人员只需自定义实现Client端、Server端,借助Android的基本平台架构便可以直接进行IPC通信。

Binder运行的实例解释
首先我们看看我们的程序跨进程调用系统服务的简单实例,实现浮动窗口部分代码:

//获取WindowManager服务引用
WindowManager wm = (WindowManager)getSystemService(getApplication().WINDOW_SERVICE);
//布局参数layoutParams相关设置略...
View view=LayoutInflater.from(getApplication()).inflate(R.layout.float_layout, null);
//添加view
wm.addView(view, layoutParams);

注册服务
在Android开机启动过程中,Android会初始化系统的各种Service,并将这些Service向ServiceManager注册(即让ServiceManager管理)。这一步是系统自动完成的。

获取服务:客户端想要得到具体的Service直接向ServiceManager要即可。客户端首先向ServiceManager查询得到具体的Service引用,通常是Service引用的代理对象,对数据进行一些处理操作。即第二行代码中,得到的wmWindowManager对象的引用。

使用服务:通过这个引用向具体的服务端发送请求,服务端执行完成后就返回。即第6行调用WindowManager的addView函数,将触发远程调用,调用的是运行在systemServer进程中的WindowManager的addView函数。

使用服务的具体执行过程

1.Client通过获得一个server的代理借口,对server进行调用。

2.代理接口中定义的方法与Server中定义的方法是一一对应的。

3.client调用某个代理接口中的方法时,代理接口的方法会将client传递的参数打包成Parcel对象。

4.代理接口将Parcel发送给内核中的binder driver。

5.server会读取binder driver中的请求数据,如果是发送给自己的,解包Parcel对象,处理并将结果返回。

6.整个的调用过程是一个同步过程,在server处理的时候,client会block住。因此client调用过程不应在主线程。

以上就是Binder机制原理的简单介绍,后面以后会以AIDL来具体介绍Binder机制的使用,加深对其的了解。

原文链接:
https://www.jianshu.com/p/4920c7781afe

简单理解Binder机制的原理相关推荐

  1. 从mediaserver入手快速理解binder机制(最简单理解binder)

    (一) 概述    Android的binder机制提供一种进程间通信的方法,使一个进程可以以类似远程过程调用的形式调用另一个进程所提供的功能.binder机制在Java环境和C/C++环境都有提供. ...

  2. 深入理解Binder机制4-bindService过程分析

    一.概述 1.1 Binder架构 Android内核基于Linux系统,而Linux系统进程间通信方式有很多,如管道,共g享内存,信号,信号量,消息队列,套接字.而Android为什么要用binde ...

  3. 简单理解redis epoll运行原理

    文章目录 I/O模型: BlockingIO(BIO) Non-blocking I/O(NIO) redis epoll 为什么epoll快? 就绪链表怎么维护? redis 是一个单线程却性能非常 ...

  4. 理解Android Binder机制(1/3):驱动篇

    Binder的实现是比较复杂的,想要完全弄明白是怎么一回事,并不是一件容易的事情. 这里面牵涉到好几个层次,每一层都有一些模块和机制需要理解.这部分内容预计会分为三篇文章来讲解.本文是第一篇,首先会对 ...

  5. Android之最好理解的Binder机制

    转载:http://weishu.me/2016/01/12/binder-index-for-newer/ Binder学习指南 发表于 2016-01-12   |   92条评论   |   3 ...

  6. 一文分析Binder机制和AIDL的理解

    为什么要去理解Android的进程间通信机制 对于Android开发工程师来说,如果不去理解进程间通信机制也可以使用系统提供的API完成应用开发,但如果想要达到更高的层级,那么就不能简单只会调用API ...

  7. Android 进阶8:进程通信之 Binder 机制浅析

    读完本文你将了解: IBinder Binder Binder 通信机制 Binder 驱动 Service Manager Binder 机制跨进程通信流程 Binder 机制的优点 总结 Than ...

  8. Android进阶(六)Binder机制

    一.进程通信 1.进程隔离: 进程隔离是为保护操作系统中进程互不干扰而设计的一组不同硬件和软件的技术.进程数据不共享,进程A的虚拟地址和进程B的虚拟地址不同,这样就防止进程A将数据信息写入进程B,保证 ...

  9. 入门启发:音视频的简单理解

    算机技术领域中,『音视频技术』应该说算是较复杂的小门类.较复杂的东西有个简单的入门指引,或者有前辈带路是很重要的. 前阵子,因为项目中急需音视频技术,虽然网上资料看似很丰富,但对初学者来说,很多资料都 ...

  10. 理解 Android 的 Binder 机制

    Binder机制的工作流程 1.客户端获取服务端的代理对象(proxy).我们需要明确的是客户端进程并不能直接操作服务端中的方法,如果要操作服务端中的方法,那么有一个可行的解决方法就是在客户端建立一个 ...

最新文章

  1. 浅谈C中的指针和数组(一)
  2. 惠普打印机节能环保认证证书_学生在家学习 入门级喷墨打印机 300元-500元档
  3. 活动平台为何没有x86?_一个由跨平台产生的浮点数bug | 有你意想不到的结果
  4. Jenkins自动编译库并上传服务器
  5. 预告 | 4月22日,CVPR 2021论文分享会详细介绍,学术新星云集!
  6. python 异步 生产者 消费者_python 生产者消费者模式 - 刘江的python教程
  7. Flutter高级第1篇:ListView嵌套GridView、不同终端屏幕适配方案
  8. docker容器中的网络原理(单机模式下的容器网络)
  9. FISCO BCOS Solidity 智能合约 返回多个值
  10. gulp-livereload组件使用
  11. 基于SSM+Layui图书借阅管理系统设计
  12. C/C++中使用PlaySound()播放音乐
  13. 大型网站SEO该怎么引爆流量_如何学网络推广
  14. 西安交大计算机2000年山西专业录取分数,西安交大在山西各专业录取分数.doc
  15. 三星s8php,三星S8 Type C接口连接电视体验
  16. 元数据管理 开源项目技术选型
  17. 字体Helvetica Arial,导致页面中使用中文时页面布局混乱
  18. 【思维导图】canny滤波 原理步骤细致剖析
  19. c# 无法检索解密密钥_使用C#检索Windows产品密钥
  20. mysql的join查询和多次查询比较

热门文章

  1. 关于ms17010渗透
  2. m3u8在线播放接口附成品
  3. 易飞ERP工作流解决方案之【第三方OA系统集成】
  4. 物联网|ZETA技术助力远超抄表实现智能化、精细化
  5. 初学ansys:模态分析及谐响应分析
  6. JDK1.8优雅的集合排序(集合的排序)
  7. matlab双线性插值双三次插值对CUFED5进行处理
  8. html5网页设计-表单
  9. 淘宝优惠券去哪里领?
  10. JAVA中Session的使用