前言
已经不知道多久没有学习,没有写博客了。昨天看到一句“一个好的程序员,还是一名作家。” 感觉自己不应该一天老给自己找借口说工作太忙,没时间学习。废话不多说,下面进入今天的正题那就是大多数Android程序员为之头疼的东西——Binder。但是,Binder又是面试时大多数面试官会问的问题。关于Binder的资料网上有很多很多,但是,由于Binder代码本身就比较枯燥,很多资料都是长篇大论,看着看着就看不下去了。下面简单谈谈Binder。
一、什么是Binder?
关于“什么是Binder?”这个问题,从刚哥的《Android开发艺术与探索》第二章 IPC机制 2.3.3Binder中,简单总结如下:
1、Binder是一个类,实现了IBinder接口。(直观)
2、Binder是Android中一种跨进程通信的模式。(IPC)
3、Binder是一种虚拟物理物理设备,它的设备驱动是/dev/binder。(物理层)
4、Binder是链接ServiceManager链接各种,Manager(ActivityManager\WindowManager等)和ManagerService之间的桥梁。(Android Framework )
5、Binder是一个客户端和服务端进行通信的媒介。(应用层)
可能这样直接说还是不太明白,我们从Android的整体架构来看(如下图所示,图片引用自:https://source.android.com),Binder 是处于 Android FrameWork跟Android System Services之间。
我们主要从图中也可以看出“Android系统是一种基于Binder的通信机制(个人观点,如果不对请指正)”。
二、Binder的应用场景
那么什么时候会用到Binder昵?那就是跨进程通信(IPC)时,如上图所示Android调用所有的Android System Service时都会用到Binder,主要包括AIDL和Messenger,说到这里还是不得不提一下操作系统中的基础知识:什么是进程?进程与线程有什么区别?
进程:进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位.
线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.
区别:一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.一个程序至少有一个进程,一个进程至少有一个线程.进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
什么是AIDL?怎么用?
*AIDL:Android Interface definition Language 安卓接口定义语言
(1)作用:发布和调用远程服务,实现跨进程通信
(2)将服务的aidl放到对应的src文件夹中,工程的gen会产生对应的接口类
(3)通过bindservice方法绑定远程服务
(4)通过IBinder 获取到的对象,该对象既可以和我们的进程通信,又可以和远程进程通信,充当了中间通信的角色。
三、浅谈Binder的工作原理
关于Binder的工作原理的资料非常多,我目前看的也有些晕,不对的地方请大家指正,个人理解如下:
关于Binder的架构模式是C/S模式,主要有四个对象Client、Server、Service Manager、Binder Driver,从图中我们可以看出四个对象的关系有些类似于互联网:Clinet-客户端,Server-服务端,ServiceManager-DNS,Binder Driver-路由器。
“Android系统Binder机制中的四个组件Client、Server、Service Manager和Binder驱动程序的关系如下图(引用自老罗的博客)所示:
从图中我们不难看出:
1. Client、Server和Service Manager实现在用户空间中,Binder驱动程序实现在内核空间中。
2. Binder驱动程序和Service Manager在Android平台中已经实现,开发者只需要在用户空间实现自己的Client和Server。
3. Binder驱动程序提供设备文件/dev/binder与用户空间交互,Client、Server和Service Manager通过open和ioctl文件操作函数与Binder驱动程序进行通信。
4. Client和Server之间的进程间通信通过Binder驱动程序间接实现。
5. Service Manager是一个守护进程,用来管理Server,并向Client提供查询Server接口的能力。
总结
看了好几篇文章看的还是有些晕,下面用一张图来简单总结一下自己对Binder的认识,如有问题,请大家指正。
参考文献
1、《Android开发艺术与探索》
2、Android进程间通信(IPC)机制Binder简要介绍和学习计划