- 浏览: 596574 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (154)
- java (31)
- Struts (3)
- Hibernate (8)
- Spring (6)
- JS (14)
- DWR (1)
- Oracle (1)
- SQL Server (0)
- JSF (0)
- JPA (0)
- Grails (3)
- Ajax (1)
- Extjs (0)
- jQuery (4)
- MySQL (2)
- 正则表达式 (2)
- 其他 (6)
- 计算机应用 (7)
- Groovy (8)
- Google (1)
- Web (2)
- MongoDB Java Driver (1)
- mongodb (1)
- Linux (3)
- HTML (1)
- Tomcat (3)
- Eclipse (2)
- JSP (1)
- 缓存 (1)
- 动态 (1)
- 问题与解决 (3)
- HY (1)
- Android (35)
- LBS (1)
最新评论
-
u012136165:
list 方法:纠正:[2,5].add(1,9) ...
Groovy的list和map -
bruce.yuan:
误人子弟的文章。已经看到N个人转了这个帖子,这要贻害多少新人啊 ...
理解并解决GBK转UTF-8奇数中文乱码 -
思念-悲伤:
特意登录上来,感谢下!
理解String的compareTo()方法返回值 -
bo_hai:
总结的好,有效。
理解String的compareTo()方法返回值 -
u012678420:
在onCreate方法中获取某个View的宽度和高度
在上一篇文章(Service使用方式)中,介绍了Android进程间通信(IPC)的使用,并给出了一个示例。但并没有深入分析aidl是怎样可以做到进程间通信的,它的执行过程是怎样的?
这篇文章来分析IRemoteService.aidl的执行过程,并理解aidl是怎样跨进程通信的。
当我们创建IRemoteService.aidl文件时,IDE会为我们在gen目录中创建相应的文件。
/** This file is auto-generated. DO NOT MODIFY. * Original file: F:\\workspace\\AndroidImprove\\src\\com\\example\\aidl\\IRemoteService.aidl */ package com.example.aidl; public interface IRemoteService extends android.os.IInterface { /** Local-side IPC implementation stub class. */ public static abstract class Stub extends android.os.Binder implements com.example.aidl.IRemoteService { private static final java.lang.String DESCRIPTOR = "com.example.aidl.IRemoteService"; /** Construct the stub at attach it to the interface. */ public Stub() { this.attachInterface(this, DESCRIPTOR); } /** * Cast an IBinder object into an com.example.aidl.IRemoteService interface, * generating a proxy if needed. */ public static com.example.aidl.IRemoteService asInterface(android.os.IBinder obj) { if ((obj==null)) { return null; } android.os.IInterface iin = (android.os.IInterface)obj.queryLocalInterface(DESCRIPTOR); if (((iin!=null)&&(iin instanceof com.example.aidl.IRemoteService))) { return ((com.example.aidl.IRemoteService)iin); } return new com.example.aidl.IRemoteService.Stub.Proxy(obj); } public android.os.IBinder asBinder() { return this; } @Override public boolean onTransact(int code, android.os.Parcel data, android.os.Parcel reply, int flags) throws android.os.RemoteException { switch (code) { case INTERFACE_TRANSACTION: { reply.writeString(DESCRIPTOR); return true; } case TRANSACTION_register: { data.enforceInterface(DESCRIPTOR); com.example.aidl.IRemoteCallback _arg0; _arg0 = com.example.aidl.IRemoteCallback.Stub.asInterface(data.readStrongBinder()); this.register(_arg0); reply.writeNoException(); return true; } case TRANSACTION_unregister: { data.enforceInterface(DESCRIPTOR); com.example.aidl.IRemoteCallback _arg0; _arg0 = com.example.aidl.IRemoteCallback.Stub.asInterface(data.readStrongBinder()); this.unregister(_arg0); reply.writeNoException(); return true; } case TRANSACTION_execute: { data.enforceInterface(DESCRIPTOR); this.execute(); reply.writeNoException(); return true; } case TRANSACTION_getStatus: { data.enforceInterface(DESCRIPTOR); java.lang.String _arg0; _arg0 = data.readString(); int _result = this.getStatus(_arg0); reply.writeNoException(); reply.writeInt(_result); return true; } } return super.onTransact(code, data, reply, flags); } private static class Proxy implements com.example.aidl.IRemoteService { private android.os.IBinder mRemote; Proxy(android.os.IBinder remote) { mRemote = remote; } public android.os.IBinder asBinder() { return mRemote; } public java.lang.String getInterfaceDescriptor() { return DESCRIPTOR; } //注册回调 public void register(com.example.aidl.IRemoteCallback callback) throws android.os.RemoteException { android.os.Parcel _data = android.os.Parcel.obtain(); android.os.Parcel _reply = android.os.Parcel.obtain(); try { _data.writeInterfaceToken(DESCRIPTOR); _data.writeStrongBinder((((callback!=null))?(callback.asBinder()):(null))); mRemote.transact(Stub.TRANSACTION_register, _data, _reply, 0); _reply.readException(); } finally { _reply.recycle(); _data.recycle(); } } //取消注册回调 public void unregister(com.example.aidl.IRemoteCallback callback) throws android.os.RemoteException { android.os.Parcel _data = android.os.Parcel.obtain(); android.os.Parcel _reply = android.os.Parcel.obtain(); try { _data.writeInterfaceToken(DESCRIPTOR); _data.writeStrongBinder((((callback!=null))?(callback.asBinder()):(null))); mRemote.transact(Stub.TRANSACTION_unregister, _data, _reply, 0); _reply.readException(); } finally { _reply.recycle(); _data.recycle(); } } //执行回调 public void execute() throws android.os.RemoteException { android.os.Parcel _data = android.os.Parcel.obtain(); android.os.Parcel _reply = android.os.Parcel.obtain(); try { _data.writeInterfaceToken(DESCRIPTOR); mRemote.transact(Stub.TRANSACTION_execute, _data, _reply, 0); _reply.readException(); } finally { _reply.recycle(); _data.recycle(); } } //获取状态 public int getStatus(java.lang.String flag) throws android.os.RemoteException { android.os.Parcel _data = android.os.Parcel.obtain(); android.os.Parcel _reply = android.os.Parcel.obtain(); int _result; try { _data.writeInterfaceToken(DESCRIPTOR); _data.writeString(flag); mRemote.transact(Stub.TRANSACTION_getStatus, _data, _reply, 0); _reply.readException(); _result = _reply.readInt(); } finally { _reply.recycle(); _data.recycle(); } return _result; } } static final int TRANSACTION_register = (android.os.IBinder.FIRST_CALL_TRANSACTION + 0); static final int TRANSACTION_unregister = (android.os.IBinder.FIRST_CALL_TRANSACTION + 1); static final int TRANSACTION_execute = (android.os.IBinder.FIRST_CALL_TRANSACTION + 2); static final int TRANSACTION_getStatus = (android.os.IBinder.FIRST_CALL_TRANSACTION + 3); } //注册回调 public void register(com.example.aidl.IRemoteCallback callback) throws android.os.RemoteException; //取消注册回调 public void unregister(com.example.aidl.IRemoteCallback callback) throws android.os.RemoteException; //执行回调 public void execute() throws android.os.RemoteException; //获取状态 public int getStatus(java.lang.String flag) throws android.os.RemoteException; }
在ClientActivity绑定远程Service并建立连接时会调用ServiceConnection.onServiceConnected(ComponentName name, IBinder service)
public void onServiceConnected(ComponentName name, IBinder service) { remoteService = IRemoteService.Stub.asInterface(service); //注册回调 try { remoteService.register(remoteCallback); } catch (RemoteException e) { e.printStackTrace(); } }
IBinder service是从RemoteService返回的IRemoteService.Stub iBinder,这个对象是Server应用进程中的对象。
IRemoteService.Stub.asInterface(service)在本地创建了一个代理
public static com.example.aidl.IRemoteService asInterface(android.os.IBinder obj)
{
if ((obj==null)) {
return null;
}
android.os.IInterface iin = (android.os.IInterface)obj.queryLocalInterface(DESCRIPTOR);//这里肯定返回null
if (((iin!=null)&&(iin instanceof com.example.aidl.IRemoteService))) {
return ((com.example.aidl.IRemoteService)iin);
}
return new com.example.aidl.IRemoteService.Stub.Proxy(obj);//创建一个本地代理
}
当使用remoteService调用方法时,其实是调用了本地com.example.aidl.IRemoteService.Stub.Proxy对象的方法,从Proxy方法中可以看到,每个方法都执行了mRemote.transact(Stub.TRANSACTION_xxx, _data, _reply, 0);。
如:
//获取状态 public int getStatus(java.lang.String flag) throws android.os.RemoteException { android.os.Parcel _data = android.os.Parcel.obtain(); android.os.Parcel _reply = android.os.Parcel.obtain(); int _result; try { _data.writeInterfaceToken(DESCRIPTOR); _data.writeString(flag); mRemote.transact(Stub.TRANSACTION_getStatus, _data, _reply, 0); _reply.readException(); _result = _reply.readInt(); } finally { _reply.recycle(); _data.recycle(); } return _result; }
这一过程是把Client端的参数转换成Parcel(_data)传递到Server端,而在Server端又会把返回数据保存到_reply中,这就形成了一次交互。
mRemote是远程对象,transact方法会执行onTransact方法
public final boolean transact(int code, Parcel data, Parcel reply, int flags) throws RemoteException { if (Config.LOGV) Log.v("Binder", "Transact: " + code + " to " + this); if (data != null) { data.setDataPosition(0); } boolean r = onTransact(code, data, reply, flags); if (reply != null) { reply.setDataPosition(0); } return r; }
这样就会执行远程的onTransact方法,
case TRANSACTION_getStatus: { data.enforceInterface(DESCRIPTOR); java.lang.String _arg0; _arg0 = data.readString(); int _result = this.getStatus(_arg0); reply.writeNoException(); reply.writeInt(_result); return true; }
注意 int _result = this.getStatus(_arg0);,这就调用了Server端的getStatus(String flag),并把返回结果写到Client端的代理Proxy对象的_reply中
到此,aidl通信过程就完成了。
PS: aidl通信有点复杂,但仔细分析并不是很难
发表评论
-
Service使用方式
2011-11-13 15:23 6056使用Service的场合: ... -
在onCreate方法中获取某个View的宽度和高度
2011-10-08 14:54 14469有时候需要在onCreate方法中知道某个View组件的宽度和 ... -
不加载图片,仅仅获取图片文件分辨率
2011-10-08 11:09 3977当从SD卡中获取图片时,如果图片太大,加载会出现溢出异常。因此 ... -
图片移动和缩放
2011-09-29 22:15 2136import android.graphics.Matr ... -
定时任务
2011-09-28 00:53 1518定时任务有执行一次和重复执行两种 public cla ... -
几种创建LayoutInflater对象的方法
2011-09-28 00:51 1872LayoutInflater layoutInflate ... -
判断网络类型及是否有网络
2011-09-28 00:49 2787判断当前是否有可用网络 public boolean ... -
设置全屏
2011-09-26 23:40 19261.编程方式 public void setFullS ... -
dip与px单位之间转换
2011-09-25 10:11 1644//转换dip为px public static in ... -
屏幕尺寸(高、宽)
2011-09-25 10:11 1900Display display = getWindowM ... -
判断手机外存(SD卡)状态
2011-09-25 10:07 2163public int getExternalStorag ... -
SQLite数据类型
2011-09-25 10:03 9355一般数据采用的固 ... -
使用WebView实现腾讯微博OAuth登录
2011-09-24 21:11 4890接着上一篇文章"使用WebView实现新浪微博OAu ... -
使用WebView实现新浪微博OAuth登录
2011-09-20 12:18 8505#新浪官方下载SDK(weibo4android) h ... -
高效率下载图片——防止内存溢出
2011-09-18 13:09 2236在应用中经常需要下载很多的图片,因此,写好图片下载部分的代码非 ... -
PopupWindow使用
2011-09-16 14:05 1823使用PopupWindow来显示一个浮层 点击按钮后弹出 ... -
Android通知
2011-09-07 17:56 1931private void showNotification() ... -
AlarmManager.RTC和ELAPSED_REALTIME的区别
2011-09-04 17:33 30062AlarmManager.RTC,硬件闹钟,不唤醒手机( ... -
开机自启动
2011-09-04 13:55 1653经常会有这样的需求,当手机开机后立刻启动一个服务或者一个活动。 ... -
Android虚拟机(DVM)内存分配——内存溢出问题
2011-09-03 17:19 9922大家都知道Android的上层应用是基于 Dalvik ...
相关推荐
在AIDLDemo项目中,可以深入研究服务器端的`IMyService.aidl`文件、服务实现类(如`MyServiceImpl.java`)和客户端的调用代码(如`MainActivity.java`),以理解AIDL的工作原理和使用方法。 通过AIDLDemo项目的学习...
在Android系统中,AIDL(Android Interface Definition Language)是一种接口定义...通过分析`AidlServer`和`AidlClient`的代码,开发者可以深入理解AIDL的工作原理,并将其应用到自己的项目中,实现更复杂的交互需求。
本篇文章将深入探讨AIDL的原理、使用方法以及其在IPC中的作用,同时结合提供的"aidlStudy"和"aidlClient"两个源码示例进行详细解析。 **1. AIDL简介** AIDL是Android系统中用于定义接口的一种语言,它允许开发者在...
本篇文章将深入探讨如何使用AIDL传递基础数据类型。 **AIDL简介** AIDL允许开发者定义接口,这些接口可以被Android系统用来在不同进程中暴露服务。它的工作原理类似于Java的接口,但是AIDL接口中的方法可以包含参数...
通过查看和分析这些源代码,开发者可以深入理解AIDL的工作原理及其在项目中的实际应用。 **标签解析:** "android"、"源码"、"Java" 这些标签指示了这个项目是基于Android平台,使用Java语言编写,并且包含了可查看...
**标题解析:** "AidlDemo(简单aidl的例子.zip" 这个标题表明这是...这个"AidlDemo"项目是深入理解Android IPC和AIDL的好起点,通过分析源代码,学习者可以直观地看到AIDL在实际项目中的运用,从而更好地掌握这一技术。
下面我们将深入探讨AIDL的工作原理、使用场景以及如何通过提供的"AIDL_client"和"AIDL_service"文件来实现这一通信机制。 **AIDL基本概念** AIDL是Android提供的一种机制,使得运行在不同进程中的Android组件能够...
通过分析和运行这个项目,你可以更深入地理解AIDL的工作原理和应用场景。 综上所述,AIDL在Android中扮演着跨应用通信的关键角色,通过定义接口和数据类型,使得不同进程间可以安全、有效地交换信息。理解和熟练...
通过分析这些源码,你可以更深入地理解AIDL的工作原理,包括服务端如何实现AIDL接口,客户端如何调用服务端的方法,以及如何处理异常和错误。 总之,AIDL是Android系统中实现跨进程通信的重要工具,尤其适用于需要...
本案例"aidl案例,包含客户端和服务端"就是一个典型的AIDL应用示例,通过它我们可以深入理解AIDL的工作原理以及如何创建和使用AIDL服务。 **一、AIDL基础** AIDL是一种接口定义语言,用于描述服务提供的方法。通过...
本实例将深入探讨AIDL的基本概念、工作原理以及如何通过源码分析其在实际项目中的应用。 首先,我们要理解AIDL的核心作用是定义接口,这个接口可以被两个独立的进程使用。当一个服务(Service)在自己的进程中运行...
通过分析和运行这个示例,开发者可以更深入地理解AIDL的工作流程,掌握多进程通信的关键技术。 总之,Android的AIDL机制是解决多进程通信问题的有效工具,它通过定义接口的方式简化了跨进程调用的过程,让开发者...
在给定的“aidl,多进程交互”主题中,我们将深入探讨AIDL的工作原理以及如何使用它来实现多进程间的通信。 **一、AIDL基础** 1. **定义接口**:首先,我们需要创建一个`.aidl`文件,该文件中定义了服务端暴露给...
总结来说,这个压缩包提供了AIDL服务端与客户端的实践案例,可以帮助开发者深入理解AIDL的工作原理和使用方法。通过学习这个例子,你可以掌握如何定义AIDL接口、如何在服务端实现接口、如何在客户端调用服务端的方法...
本篇文章将深入解析AIDL的基本概念、工作原理以及如何通过实例来实现AIDL。 **AIDL简介** AIDL是Android用于定义接口的专用语言,它允许服务(Service)在不同进程中暴露接口,使得其他进程可以通过这些接口调用...
通过学习和分析这个Demo,开发者可以深入理解AIDL的工作原理,并熟练运用到实际项目中,实现高效且安全的跨进程通信。 总结来说,AIDL是Android中进行进程间通信的关键工具,它简化了服务端和客户端之间的交互,...
本实例将深入讲解如何使用AIDL,并通过`AIDLServer`和`AIDLClient`两个项目来演示其工作原理。 首先,我们需要了解AIDL的基本结构。AIDL文件是一种简单的接口定义语言,类似于Java接口,但包含了一些特定的语法来...
总之,"androidstudio开发的aidl小demo"是一个很好的学习资源,通过这个项目,开发者可以深入理解AIDL的工作原理和使用方法,提升Android应用开发的技能。在实际项目中,合理运用AIDL可以解决许多跨进程通信的问题,...
#### 一、IPC(Inter-Process Communication)概念与原理 **IPC**,即进程间通信(Inter-Process Communication),指的是不同进程间的通信方式。在Android系统中,由于安全性和资源隔离的需求,不同的应用程序或者...
本教程将通过一个完整的AIDL Demo来深入理解其工作原理和应用,涉及到服务端和客户端两个工程的实现。 首先,我们要明白AIDL的基本概念。它是Android系统提供的一种接口定义语言,类似于Java中的接口,但它的目的是...