Android的IPC机制

转载 2011年01月10日 10:14:00

ServiceManager启动
源码:frameworks/base/cmds/servicemanager/Service_manager.c

 

int main(int argc, char **argv)

{

    struct binder_state *bs;

    void *svcmgr = BINDER_SERVICE_MANAGER;  //以此标识服务管理器

 

    bs = binder_open(128*1024);  //打开Binder驱动,在kernel/Common/Drivers/misc/binder.c中

 

    if (binder_become_context_manager(bs)) {  //在kernel/Common/Drivers/misc/binder.c中进行处理,将bs变成内容管理者

        LOGE("cannot become context manager (%s)/n", strerror(errno));

        return -1;

    }

 

    svcmgr_handle = svcmgr;

    binder_loop(bs, svcmgr_handler);  //进入循环等待数据的到来

    return 0;

}

Binder驱动中采用RB树的方式进行存储管理,采用linux的ioctl机制进行与用户程序进行交互。ServiceManager作为守护进程,使用链表保存了注册进来的其他Service,在其他服务的请求到来时,将请求通过ioctl写入驱动,将驱动和响应读出来再传递给发起请求的服务。

 

Binder库
利用Binder驱动实现IPC通信

源码:frameworks/base/include/utils/*

frameworks/base/libs/utils/*

主要的类为:

  RefBase.h :

    引用计数,定义类RefBase。

  Parcel.h :

    为在IPC中传输的数据定义容器,定义类Parcel

  IBinder.h:

    Binder对象的抽象接口, 定义类IBinder

  Binder.h:

    Binder对象的基本功能, 定义类BBinder和BpRefBase,BBinder类用于服务器端Binder,即远端Binder

  BpBinder.h:

  BpBinder的功能,定义类BpBinder,用于客户端Binder

  IInterface.h:

  为抽象经过Binder的接口定义通用类,

    定义类IInterface,类模板BnInterface,类模板BpInterface

  ProcessState.h

    表示进程状态的类,定义类ProcessState

  IPCThreadState.h

表示IPC线程的状态,定义类IPCThreadState

 

IPC流程
守护进程ServiceManager负责周转各进程间的数据交互服务。

进程A通过IServiceManager::getService函数取得IBinder,在此IBinder上调用Transaction进行数据传输。此IBinder会利用IPCThreadState对象通过与Binder驱动对话,将请求交由KERNEL中的驱动处理。


Binder驱动采用同步的方式将数据传递给远端Binder对象,远端Binder对象进行数据处理,将处理结果原路写回,藉由驱动再传递回IBinder。见示意图说明。

 

 


 

Service的实现方法
假设要实现一个TestService,可按如下方法操作:

1.       定义ITestService.h文件,定义ITestService接口并从IInterface类继承,在其中使用DECLARE_META_INTERFACE(TestService)宏

2.       定义ITestService.cpp文件,在其中使用IMPLEMENT_META_INTERFACE(TestService, "android.my.ITestService")

3.       实现BnTestService类,实现onTransact函数

4.       如果需要,则实现BpTestService类

5.       在TestService启动时利用IServiceManager::addService将自己注册到服务管理器

6.       使用此服务时只需使用IServiceManager::getService函数取到ITestService接口即可


   


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/caowenbin/archive/2010/10/15/5942768.aspx

举报

相关文章推荐

[读书笔记]Android IPC机制(一)

每天都要写点笔记,哪怕是自己给自己看也好。一、Android IPC简介1.Android进程间通信的几种方式: Bundle(Intent) 文件 AIDL Messenger ContentPro...

Android的IPC机制(七)—— Socket的原理简析与使用

在前面的几篇文章中,我们介绍了许多在Android中有关进程间通信的方式,但都是在一个设备上进行的进程间通信,而这时候我们两个应用在不同的设备上的时候,在这个时候我们就不能通过前方介绍的那些方法来解决...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

2.1 Android进程间通信(IPC)----Binder机制的简单介绍

Binder机制简介: 进程间通信机制(通俗地讲,就是远程过程调用(RPC)功能),Binder的组成:   由Client、Server、Service Manager(管理Android系统的所...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)