IPC进程间通信 - AIDL+Binder
2016-05-26 22:56
393 查看
原理
http://www.linuxidc.com/Linux/2012-07/66195.htm
服务端,客户端处在用户空间,而binder驱动处在内核空间。
服务器端。一个Binder服务器端就是一个Binder类的对象。当创建一个服务端Binder对象后,服务端内部就会开启一个线程,这个线程用于接收内核空间中的binder驱动发送的信息,收到消息后,会执行相关的服务代码。
Binder驱动。当服务端成功创建一个Binder对象后,内核空间中的Binder驱动也会相应创建一个mRemote对象(mRemote成员变量实际上是一个BinderProxy对象),该对象的类型也是Binder类。客户就可以借助这个mRemote对象来访问远程服务。
客户端。客户端要想访问服务端Binder的远程服务,就必须获取服务端远程服务的Binder对象在binder驱动层对应的mRemote引用。当获取到mRemote对象的引用后,就可以通过此引用调用相应Binder对象的服务了。
serviceManger,它本身也是一个service,但它管理着系统其它的service。Framework提供了一个系统函数BinderInternal.getContextObject(),可以获取该Service对应的Binder引用。通过这个静态函数返回的ServiceManager提供的方法又可以获取其它系统Service的Binder引用。所以serviceManager是整个系统service的总管,也是系统的一个核心对象,它是开机就自启动的。其它的service都要向它进行注册并保管引用,这样保证所有的服务都可以通过servericeManger获取到引用。这种设计模式的一个好处就是仅暴露一个Binder引用,而其它的系统服务可以隐藏起来,从而有助于系统服务的扩展,以及调用系统服务的安全检查 。
---------------------------------------------------------------------------------------------
在Android系统的Binder机制中,由一系统组件组成,分别是Client、Server、Service Manager和Binder驱动程序,其中Client、Server和Service Manager运行在用户空间,Binder驱动程序运行内核空间。
Binder就是一种把这四个组件粘合在一起的粘结剂,核心组件便是Binder驱动程序;Service Manager提供了辅助管理的功能,Client和Server正是在Binder驱动和Service Manager提供的基础设施上,进行Client-Server之间的通信。
1. Client、Server和Service Manager实现在用户空间中,Binder驱动程序实现在内核空间中
2. Binder驱动程序和Service Manager在Android平台中已经实现,开发者只需要在用户空间实现自己的Client和Server
3. Binder驱动程序提供设备文件/dev/binder与用户空间交互,Client、Server和Service Manager通过open和ioctl文件操作函数与Binder驱动程序进行通信
4. Client和Server之间的进程间通信通过Binder驱动程序间接实现
5. Service Manager是一个守护进程,用来管理Server,并向Client提供查询Server接口的能力
AIDL使用方法
代码参考:http://www.cnblogs.com/mandroid/archive/2011/02/26/1965428.html
《疯狂android讲义3》
IPC调用会挂起应用程序导致界面失去响应. 这种情况应该考虑单起一个线程来处理。IPC的调用步骤:
1. 声明一个接口类型的变量,该接口类型在.aidl文件中定义。
2. 实现ServiceConnection。
3. 调用ApplicationContext.bindService(),并在ServiceConnection实现中进行传递.
4. 在ServiceConnection.onServiceConnected()实现中,你会接收一个IBinder实例(被调用的Service). 调用 YourInterfaceName.Stub.asInterface((IBinder)service)将参数转换YourInterface类 型。
5. 调用接口中定义的方法。 你总要检测到DeadObjectException异常,该异常在连接断开时被抛出。它只会被远程方法抛出。
6. 断开连接,调用接口实例中的ApplicationContext.unbindService()
来自为知笔记(Wiz)
http://www.linuxidc.com/Linux/2012-07/66195.htm
服务端,客户端处在用户空间,而binder驱动处在内核空间。
服务器端。一个Binder服务器端就是一个Binder类的对象。当创建一个服务端Binder对象后,服务端内部就会开启一个线程,这个线程用于接收内核空间中的binder驱动发送的信息,收到消息后,会执行相关的服务代码。
Binder驱动。当服务端成功创建一个Binder对象后,内核空间中的Binder驱动也会相应创建一个mRemote对象(mRemote成员变量实际上是一个BinderProxy对象),该对象的类型也是Binder类。客户就可以借助这个mRemote对象来访问远程服务。
客户端。客户端要想访问服务端Binder的远程服务,就必须获取服务端远程服务的Binder对象在binder驱动层对应的mRemote引用。当获取到mRemote对象的引用后,就可以通过此引用调用相应Binder对象的服务了。
serviceManger,它本身也是一个service,但它管理着系统其它的service。Framework提供了一个系统函数BinderInternal.getContextObject(),可以获取该Service对应的Binder引用。通过这个静态函数返回的ServiceManager提供的方法又可以获取其它系统Service的Binder引用。所以serviceManager是整个系统service的总管,也是系统的一个核心对象,它是开机就自启动的。其它的service都要向它进行注册并保管引用,这样保证所有的服务都可以通过servericeManger获取到引用。这种设计模式的一个好处就是仅暴露一个Binder引用,而其它的系统服务可以隐藏起来,从而有助于系统服务的扩展,以及调用系统服务的安全检查 。
---------------------------------------------------------------------------------------------
在Android系统的Binder机制中,由一系统组件组成,分别是Client、Server、Service Manager和Binder驱动程序,其中Client、Server和Service Manager运行在用户空间,Binder驱动程序运行内核空间。
Binder就是一种把这四个组件粘合在一起的粘结剂,核心组件便是Binder驱动程序;Service Manager提供了辅助管理的功能,Client和Server正是在Binder驱动和Service Manager提供的基础设施上,进行Client-Server之间的通信。
1. Client、Server和Service Manager实现在用户空间中,Binder驱动程序实现在内核空间中
2. Binder驱动程序和Service Manager在Android平台中已经实现,开发者只需要在用户空间实现自己的Client和Server
3. Binder驱动程序提供设备文件/dev/binder与用户空间交互,Client、Server和Service Manager通过open和ioctl文件操作函数与Binder驱动程序进行通信
4. Client和Server之间的进程间通信通过Binder驱动程序间接实现
5. Service Manager是一个守护进程,用来管理Server,并向Client提供查询Server接口的能力
AIDL使用方法
代码参考:http://www.cnblogs.com/mandroid/archive/2011/02/26/1965428.html
《疯狂android讲义3》
IPC调用会挂起应用程序导致界面失去响应. 这种情况应该考虑单起一个线程来处理。IPC的调用步骤:
1. 声明一个接口类型的变量,该接口类型在.aidl文件中定义。
2. 实现ServiceConnection。
3. 调用ApplicationContext.bindService(),并在ServiceConnection实现中进行传递.
4. 在ServiceConnection.onServiceConnected()实现中,你会接收一个IBinder实例(被调用的Service). 调用 YourInterfaceName.Stub.asInterface((IBinder)service)将参数转换YourInterface类 型。
5. 调用接口中定义的方法。 你总要检测到DeadObjectException异常,该异常在连接断开时被抛出。它只会被远程方法抛出。
6. 断开连接,调用接口实例中的ApplicationContext.unbindService()
来自为知笔记(Wiz)
相关文章推荐
- linker command failed with exit code 1 (use -v to see invocation)报错
- 解决open-vm-tools安装时Failed to get unit file state for run-vmblockx2dfuse.mount
- 报错"std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >::at(unsigne
- 检测是否超出int范围 && 11. Container With Most Water
- scala之trait详解一
- Theano: CNMeM is disabled, CuDNN not available
- X64操作系统组件Jmail无法正常服务问题
- X64操作系统组件Jmail无法正常服务问题
- Crazy Thairs_poj3378_DP+离散+高精度+树状数组
- WM_PAINT
- int main(int argc,char* argv[])详解
- 如何理解:int main(int argc, char** argv)
- 【CodeForces】675B - Restoring Painting(数学推导)
- 论文笔记之:Fully Convolutional Attention Localization Networks: Efficient Attention Localization for Fine-Grained Recognition
- Windows Server 2012 磁盘管理之 简单卷、跨区卷、带区卷、镜像卷和RAID-5卷
- 【CodeForces】667A - Pouring Rain(数学)
- Installation error: INSTALL_FAILED_DUPLICATE_PERMISSION
- chromium WinMain
- haartraining训练生成xml过程
- Contains Duplicate