一、AIDL代码详细解析
/*
* This file is auto-generated. DO NOT MODIFY.
* Original file: E:\\android_projects\\Android-PickerView-master\\AidlDemo\\app\\src\\main\\aidl\\com\\suning\\aidldemo\\IAddInterface.aidl
*/
package com.suning.aidldemo;
// Declare any non-default types here with import statements
/**
* 1、当客户端发起远程请求时,由于当前线程会被挂起直至服务端进程返回数据,所以如果一个远程方法是耗时的,那么不能在UI线程发起此远程请求
* 2、由于服务端的Binder方法运行在Binder线程池中,所以Binder方法不管是否是耗时操作都应采用同步的方式去实现,因为它已经运行在一个线程中
*/
public interface IAddInterface extends android.os.IInterface {
/**
* Local-side IPC implementation stub class.
*/
public static abstract class Stub extends android.os.Binder implements com.suning.aidldemo.IAddInterface {
//Binder的唯一标识,一般用于当前Binder的类名表示
private static final java.lang.String DESCRIPTOR = "com.suning.aidldemo.IAddInterface";
/**
* Construct the stub at attach it to the interface.
*/
public Stub() {
this.attachInterface(this, DESCRIPTOR);
}
/**
* Cast an IBinder object into an com.suning.aidldemo.IAddInterface interface,
* generating a proxy if needed.
* 用于将服务端的Binder对象转换成客户端所需的AIDL接口类型的对象,这种转换是区分进程的,如果客户端和服务端位于
* 统一进程,那么此方法返回的就是服务端的Stub对象本身,否则返回的是系统封装后的Stub.proxy对象
*
*/
public static com.suning.aidldemo.IAddInterface asInterface(android.os.IBinder obj) {
if ((obj == null)) {
return null;
}
//查询本地接口
android.os.IInterface iin = obj.queryLocalInterface(DESCRIPTOR);
//如果存在直接返回该对象(代表客户端与服务端在同一进程)
if (((iin != null) && (iin instanceof com.suning.aidldemo.IAddInterface))) {
return ((com.suning.aidldemo.IAddInterface) iin);
}
//返回系统封装后的Stub.proxy对象(代表客户端与服务端不在同一进程)
return new com.suning.aidldemo.IAddInterface.Stub.Proxy(obj);
}
//用于返回当前Binder对象
@Override
pu