当前位置: 首页 > news >正文

Android---进程间通信机制3

1 服务如何注册到 SM 中

\bullet getIServiceManager().addService(name, service, false);

  getIServiceManger --- new ServiceManagerProxy(new BinderProxy())

      BinderInternal.getContextObject --- 返回 BinderProxy 对象

        ProcessState::self()->getContextObject: 创建一个 BpBinder

        javaObjectForIBinder -->BinderProxy和BpBinder相互绑定

     ServiceManagerNative.asInterface

        返回 ServiceManagerProxy

\bullet addService 

    data.writeStrongBinder(service); --service == AMS --> 将 AMS放入data中

    mRemote.transact ---mRemote == BinderProxyxx

        获取 BpBinder  --- IPCThreaState::transact

          1. writeTransactionData ---out写入命令 --write  ----cmd = BC_TRANSACTION

          2. waitForResponse

              talkWithDriver --- 非常重要

                Binder_transaction

                  handle == 0 --> sm

                  1.target_node == sm

                  2.proc

                  3.保存todo,wait

                  4.创建t, tcomplete

                  5.数据拷贝

                  6.binder_transaction_binder --转换为--> handle

                  7.thread-->transaction_stack = t; ---> 方便sm找到client

                  8.t-->work.type =  BINDER_WORK_TRANSACTION; -- 给sm --> 做事

                  9.tcomplete-->type = BINDER_WORK_TRANSACTION_COMPLETE; --给client--挂起

                  10.wake_up_interruptible 唤醒sm

             client挂起

                  BR_NOOP, BR_TRANSACTION_COMPLETE

                  wait_event_freezable --- 挂起

              sm处理添加服务

                  BINDER_WORK_TRANSACTION ---要处理 cmd == BR_TRANSACTION

                          1. reply 初始化

                          2.res = func(bs, txn, &msg, &reply); --- 函数指针 --- svcmgr_handler 作用;获取或者添加service。sm 是用 svclist 保存所有服务的

                          3.binder_send_reply --- bc_reply

                          4.t-->work.type = BINDER_WORK_TRANSACTION; -- 给 client

                              tcomplete -->type = BINDER_WORK_TRANSACTION_COMPLETE; 给 SM --被挂起

                          5.wake_up_interruptible(target_wait); --- 唤醒 Client

              client 被唤醒

                  BINDER_WORK_TRANSACTION --- cmd = BR_REPLY;

              SM 处理 onTransact

                  IPCThreadState::executeCommand

                        error = reinterpret_cast<BBinder*>(tr.cookie)->transact(tr.code, buffer, &reply, tr.flags);

                        javaBBinder.ontransact --- C++

                        jboolean res = env -->CallBooleanMethod(mObject, gBinderOffsets.mExectransact,code, reinterpret_cast<jlong>(&data), reinterpret_cast<jlong>(reply), flags); -- BInder.java.execTransact方法

线程池管理:

1. 主线程 --- 不会退出,非主线程退出

2. 线程最大数 = 15 --- 非主线程

3. 主线程1个,不算在线程最大数中

4. 线程真正最大数 == 15 + 1 + 其它线程

 

 

http://www.lryc.cn/news/28991.html

相关文章:

  • Python实战,爬取金融期货数据
  • Allegro如何导入第三方网表操作指导
  • 高码率QPSK调制解调方案(FPGA实现篇)
  • Elasticsearch的RESTful Api使用
  • 软著申请需要注意的
  • SpringBoot入门 - 添加Logback日志
  • 社会实践报告
  • LeetCode 460. LFU 缓存 -- 哈希查询+双向链表
  • Dubbo 源码分析 – SPI 机制
  • JDBC概述二(JDBC编程+案例展示)
  • 广度和深度优先搜索解析与示例代码
  • 基于SLIC超像素的归一化分割算法
  • C语言刷题(4)——“C”
  • 带你看懂RuoYi动态数据源切换
  • 家有女儿必看:盲目的和青春期女儿较劲,不如掌握4个沟通技巧
  • 【VC 7/8】vCenter Server 基于文件的备份和还原Ⅰ——基于文件的备份和还原的注意事项和限制
  • 【ROS学习笔记10】ROS中配置自定义Cpp头文件和导入自定义Python库
  • svn 分支(branch)和标签(tag)管理
  • @Transactional详解
  • 机器学习:Transformer
  • pytorch-模型构建,参数访问,模型存取API接口,对比学习
  • javaEE 初阶 — 数据链路层中的以太网数据帧
  • 泼辣修图Polarr5.11.4 版,让你的创意无限延伸
  • leetcode打卡-深度优先遍历和广度优先遍历
  • 【0177】Linux中POSIX信号量实现机制
  • 跳表--C++实现
  • c#:System.Text.Json 的使用一
  • kaggle数据集下载当中所遇到的问题
  • TEX:高阶用法
  • UML 类图