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机制demo

  • 2016年05月21日 21:09
  • 6.85MB
  • 下载

Android IPC机制Binder简要介绍

  • 2016年07月16日 07:37
  • 399KB
  • 下载

Android系统进程间通信(IPC)机制Binder中的Client获得Server远程接口过程源代码分析

在上一篇文章中,我们分析了Android系统进程间通信机制Binder中的Server在启动过程使用Service Manager的addService接口把自己添加到Service Manager守...

Android Service IPC通信之Messenger机制

  • 2016年10月30日 01:40
  • 30.1MB
  • 下载

Android IPC机制详解

  • 2011年12月31日 00:16
  • 148KB
  • 下载

Android的IPC机制(三)——Binder连接池

前两篇说到AIDL的使用方法,但是当我们的项目很大时,很多模块都需要用到Service,我们总不能为每一个模块都创建一个Service吧,这样一来我们的应用就会显得很笨重。那么有没有一种解决方案叫我们...
  • ljd2038
  • ljd2038
  • 2016年02月24日 20:00
  • 3510

Android的IPC机制-Binder

  • 2012年05月26日 14:39
  • 462KB
  • 下载

浅谈Service Manager成为Android进程间通信(IPC)机制Binder守护进程之路

分类: Android2011-07-22 02:32 22663人阅读 评论(51) 收藏 举报 managerserviceandroidstructthreadbuffer   ...

Android的IPC机制——Binder

  • 2011年10月23日 18:50
  • 360KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android的IPC机制
举报原因:
原因补充:

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