Android开发接口描述

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

接口描述语言(AIDL)

译者署名:移动云_文斌

译者链接:/caowenbin

版本:Android 2.3 r1

原文

/guide/developing/tools/aidl.html (注意:3.0 r1 以后移到Appendix下)

使用AIDL设计远程接口(Designing a Remote Interface Using AIDL)

由于每个应用程序都运行在自己的进程空间,并且可以从应用程序UI运行另一个服务进程,而且经常会在不同的进程间传递对象。在Android平台,一个进程通常不能访问另一个进程的内存空间,所以要想对话,需要将对象分解成操作系统可以理解的基本单元,并且有序的通过进程边界。

通过代码来实现这个数据传输过程是冗长乏味的,Android提供了AIDL工具来处理这项工作。

AIDL (Android Interface Definition Language)是一种IDL 语言,用于生成可以在Android设备上两个进程之间进行进程间通信(IPC)的代码。如果在一个进程中(例如Activity)要调用另一个进程中(例如Service)对象的操作,就可以使用AIDL生成可序列化的参数。

AIDL IPC机制是面向接口的,像COM或Corba一样,但是更加轻量级。它是使用代理类在客户端和实现端传递数据。

使用AIDL实现IPC(Implementing IPC Using AIDL)使用AIDL实现IPC服务的步骤是:

1.创建.aidl文件-该文件(YourInterface.aidl)定义了客户端可用的

方法和数据的接口。

2.在makefile文件中加入.aidl文件-(Eclipse中的ADT插件提供管理

功能)Android包括名为AIDL的编译器,位于tools/文件夹。

3.实现接口-AIDL编译器从AIDL接口文件中利用Java语言创建接口,该

接口有一个继承的命名为Stub的内部抽象类(并且实现了一些IPC调用

的附加方法),要做的就是创建一个继承于YourInterface.Stub的类并

且实现在.aidl文件中声明的方法。

4.向客户端公开接口-如果是编写服务,应该继承Service并且重载

Service.onBind(Intent) 以返回实现了接口的对象实例

创建.aidl文件(Create an .aidl File)

AIDL使用简单的语法来声明接口,描述其方法以及方法的参数和返回值。这些参数和返回值可以是任何类型,甚至是其他AIDL生成的接口。重要的是必须导入所有非内置类型,哪怕是这些类型是在与接口相同的包中。下面是AIDL能支持的数据类型:

●Java编程语言的主要类型 (int, boolean等) —不需要 import 语句。

●以下的类 (不需要import 语句):

⏹String

⏹List-列表中的所有元素必须是在此列出的类型,包括其他AIDL生成

的接口和可打包类型。List可以像一般的类(例如List

那样使用,另一边接收的具体类一般是一个ArrayList,这些方法会

使用List接口。

⏹Map - Map中的所有元素必须是在此列出的类型,包括其他AIDL生

成的接口和可打包类型。一般的maps(例如Map

不被支持,另一边接收的具体类一般是一个HashMap,这些方法会使

用Map接口。

⏹CharSequence -该类是被TextView和其他控件对象使用的字符序

列。

●通常引引用方式传递的其他AIDL生成的接口,必须要import 语句声明

●实现了Parcelable protocol 以及按值传递的自定义类,必须要import

语句声明。

以下是基本的AIDL语法:

实现接口(Implementing the Interface)

//My AIDL file,named SomeCloss.aidl

//Note that standard comment syntax is respected.

//Comments before the import or package statements are not bubbled up

//to the generated interface,but comments above interface/method/field

//declarations are added to the generated interface.

//Include your fully-qualified package statement.

Package com.android.sample;

//See the list above for which classes need

//import statements(hint—most of them)

Import com.android.sample .IAtmService;

//Declare the interface.

iterface IBankAccountService {

//Methods can take 0 or more parameters, and

//return a value or void.

int getAccountBalance();

void setOwnerNames(in List names);

//Methods can even take other AIDL-defined parameters.

BankAccount createAccount(in String name, int startingDeposit, in IAtmService atmService);

//All non-Java primitive parameters(e.g., int, bool, etc) require;

// a directional tag indicating which way the data will go. Available

// values are in, out, inout. (Primitives are in by default, and cannot be otherwise).

// Limit the direction to what is truly needed, because marshalling parameters

// is expensive.

int getCustomerList(in String branch, out String[] customerList);

}

AIDL生成了与.aidl文件同名的接口,如果使用Eclipse插件,AIDL 会做为编译过程的一部分自动运行(不需要先运行AIDL再编译项目),如果没有插件,就要先运行AIDL。

生成的接口包含一个名为Stub的抽象的内部类,该类声明了所

有.aidl中描述的方法,Stub还定义了少量的辅助方法,尤其是asInterface(),通过它或以获得IBinder(当applicationContext.bindService()成功调用时传递到客户端的onServiceConnected())并且返回用于调用IPC方法的接口实例,更多细节参见Calling an IPC Method。

要实现自己的接口,就从YourInterface.Stub类继承,然后实现相关的方法(可以创建.aidl文件然后实现stub方法而不用在中间编译,Android

编译过程会在.java文件之前处理.aidl文件)。

这个例子实现了对IRemoteService接口的调用,这里使用了匿名对象并且只有一个getPid()接口。

// No need to import IRemoteService if it’s in the same project.

private final IRemoteService.Stub mBinder = new IRemoteService.Stub(){ public int getPid(){

return Process.myPid();

}

}

相关文档
最新文档