Android AIDL的重新理解

Android Service在工作中也用的很多,但是AIDL就用的很少了,感觉也很生疏,之前在公司也有同事做过技术讲座,而且也看过一些技术文章,但是感觉依然朦朦胧胧的。现在从事教学工作后,把AIDL又看了一遍,发现其实并不用理解的那么复杂,其实很简单的一个RPC(IPC)机制。

使用AIDL涉及到的前提是:需要跟其他应用的Service进行数据交换或者是方法调用。(也就是远程操作其他Service)。否则如果没有数据交换或方法调用,直接使用startService()即可;本地Service更加无需AIDL。 

明确这个大前提后,来看AIDL所涉及的几个知识点:

1.ServiceConnection接口:实现这个接口后可以实现Service连接状态的回调方法onServiceConnected(ComponentName component, IBinder service)和onServiceDisconnected(ComponentName component)。

2.IBinder接口

3.Binder类:Binder可以想象成一个内存共享对象,这个对象只有方法暴露出来给客户端调用。

4.Stub静态内部类:其实就是继承了Binder和实现了自己定义的AIDL接口的一个类(所谓的代理),就是一个实现了自己定义的接口的一个Binder。

5.实现了Parcelable序列化接口的自定义Java Bean:如果传输简单数据,根本没必要。(顺便说两句:1.要想把数据存储到磁盘或者是通过网络传输,一定要序列化;2.最为经常使用的Bundle其实就是一个Parcelable,可以通过Bundle来理解Parcelable)

使用AIDL要注意的地方:

1.文件名字一定要以.aidl结尾

2..aidl文件的包名很重要,Service端和调用端包名一定要保持一致。

先上一张图,说明整个调用过程和远程过程调用的原理:

Android AIDL的重新理解

下面贴出工程代码结构图:

Android AIDL的重新理解

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/4628742e2e1d880399b647cd9a2f00bc.html