AIDL (Android Interface Definition Language),通过定义通信接口来实现进程间通信。这是Google提供的一种在安卓应用进程间通信的工具。所以要了解AIDL的通信原理,我们需要围绕以下两个问题来展开。
1、为什么需要AIDL?
我们都知道AIDL的目的是进行进程间通信。所以在了解AIDL原理之前先要了解一下什么叫进程间通信。进程间通信涉及到两个名词,一个是进程间,一个是通信。进程间就是两个或多个进程之间,所以这里先要明确一个概念,进程间通信涉及到多个实体。其次是通信,什么是通信呢?打电话,发邮件,发QQ消息都是通信,他们之间的共同点就是数据交换。所以简单来说,进程间通信就是多个多个实体间的数据交换,而且这些数据都是运行时数据,因为通信实体是运行时产生的。那么一般情况下,我们的应用程序是怎样进行数据交换呢?最简单的办法就是共享内存,即建立内存共享区,然后进程B往内存共享区里写,进程A从内存共享区里读,从而完成通信。但是在安卓里是行不通的,因为单独的进程是运行在自己的虚拟机里面,有着自己的内存映射,所以内存共享没法实现,只能借助AIDL。
2、AIDL是怎么起作用的?
在这之前,我们先讨论AIDL的实现步骤:
1)、定义AIDL文件;
2)、实现AIDL文件里面定义的接口;
3)、暴露接口;
4)、调用;
这四个过程可以类比于c/s模型,如果一个客户端需要访问服务器中的某一个网页,它需要经过几个步骤呢?同样也是需要四个:
1)、定义通信规则,已经有了现有的规则——tcp/ip协议族;
2)、在服务器中编写网页文件;
3)、暴露资源文件的访问地址;
4)、客户端发起请求,获取资源,完成通信;
从上面这个对比可以看出,这里面的关键就是定义协议这一步,即定义AIDL文件的过程,之后有一个重要的过程,即编译AIDL文件,这里编译器为我们做了一个最重要的一步,生成了一个Stub类,这个类是个抽象类,继承自Binder类,并实现了我们在AIDL文件中定义的接口,所以我们最终对接口对象的操作最终都转换成了Stub对象的操作,具体的通信过程有Stub对象为我们完成了,也就是拆分对象数据,和生成对象数据这些繁琐的事情。所以AIDL的通信原理其实只是定义了通信规则,具体的实现还是靠binder.所以最终的分析结果就是,AIDL将我们需要传递的数据拆分后,通过Binder传递。在访问端AIDL把接收到的结果组装成我们期望的对象,把底层的操作屏蔽了。