Android接口定义语言AIDL
前言
这篇文章大部分是来自android开发官网和一些网上大佬的文章,这里写出来也是为了学习和记录。
正文
客户端和服务端之间的进程间通信(IPC)认可的编程接口
- 只有不同应用的客户端用IPC访问服务并在服务中处理多线程才使用AIDL。不执行跨应用的IPC可以使用Binder接口,如果想执行IPC但是不处理多线程则使用Messenger接口,总之是要先绑定服务的。
包含.aidl文件的应用,SDK工具会生成一个基于.aidl文件的Ibinder的接口,保存在项目的gen/ 目录中,服务实现IBinder接口,客户端绑定服务调用IBinder来实现IPC.
实现步骤:
- 创建.aidl文件
- 实现接口(sdk会生成接口)
- 向客户端公开接口
创建.aidl文件
支持的数据:
- java中的原语类型(int , long , char等)
- String
- CharSequence
- List(元素 必须是aldl支持的数据)
- Map(同上)
- 实现Parcelable的实体
注意:server中必须是Arraylist 或者HashMap 。非原语要指示数据走向(in、out、inout)原语默认in。要确定好你需要的方向,因为编组参数开销极大。in –>数据从客户端流向服务端,out 数据只能由服务端流向客户端,inout 则表示数据可在服务端与客户端之间双向流通。其中,数据流向是针对在客户端中的那个传入方法的对象而言的。in 为定向 tag 的话表现为服务端将会接收到一个那个对象的完整数据,但是客户端的那个对象不会因为服务端对传参的修改而发生变动;out 的话表现为服务端将会接收到那个对象的参数为空的对象,但是在服务端对接收到的空对象有任何修改之后客户端将会同步变动;inout 为定向 tag 的情况下,服务端将会接收到客户端传来对象的完整信息,并且客户端将会同步服务端对该对象的任何变动来自 https://blog.youkuaiyun.com/luoyanglizi/article/details/51958091
// IRemoteService.aidl
package com.example.android;
// Declare any non-default types here with import statements
/** Example service interface */
interface
IRemoteService
{
/** Request the process ID of this service, to do evil things with it. */
int
getPid
()
;
/** Demonstrates some basic types that you can use as parametersand return values in AIDL.*/
void
basicTypes
(
int
anInt,
long
aLong, boolean aBoolean,
float
aFloat,
double
aDouble, String aString
)
;
}
aidl文件保存在项目的src/下,生成的文件在gen/下 名字和aidl文件一样只是以.java扩展名(IRemoteService.aidl —-> IRemoteService.java)
实现接口
.java接口文件包含了Stub的子类,是父类的抽象实现
private
final
IRemoteService.Stub mBinder =
new
IRemoteService.Stub() {
public
int getPid()
{
return Process.myPid()
;
}
public
void basicTypes(int anInt, long aLong, boolean aBoolean,
float
aFloat,
double
aDouble, String aString) {
// Does nothing