深入Android架构(从线程到AIDL)_09 认识Android的主线程

server/2025/1/8 19:28:37/

目录

UI线程的诞生

練習: 绑定(Bind)远程的Service


UI线程的诞生
  • 当我们启动某一支AP时, Android就会诞生新进程(Process),并且将该AP程序加载这新诞生的进程里。每个进程在其诞生时刻,都会诞生一个主线程,又称为UI线程。
  • 在进程诞生时刻,除了诞生主线程之外,还会替主线程诞生它专用的Message Queue和Looper。如下图所示:
  • 这个Main Looper就是让主线程没事时就来执行Looper,确保主线程永远活着而不会死掉;在执行Looper时,会持续观察它的Message Queue是否有新的信息进来;如果有新信息进来的话,主线程就会尽快去处理(响应)它。
  • 在Android环境里,一个应用程序常包含有许多个类别,这些类别可以分布在不同进程里执行,或挤在一个进程里执行。例如有一个应用程序的AndroidManifest.xml文件内容如下:
    // AndroidManifest.xml
    // ………
    <activity android:name=".FirstActivity" android:label="@string/app_name">
    <intent-filter>
    <action android:name="android.intent.action.MAIN" />
    <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter> </activity>
    <activity android:name=".LoadActivity">
    <intent-filter>
    <category android:name="android.intent.category.DEFAULT" />
    </intent-filter> </activity>
    <service android:name=".LoadService" android:process=":remote">
    <intent-filter>
    <action android:name="com.misoo.pkm.REMOTE_SERVICE" />
    </intent-filter> </service>
    </application>
    </manifest>
  • Android依据这个文件而将各类别布署于两个进程里执行,如图:

        

  • 其中, FirstActivity和LoadActivity两个类别会加载预设的进程里。而LoadService则会加载于名为“remote” 的独立进程里。
  • 于是,由进程#1的主线程去执行FirstActivity和LoadActivity的onCreate()等函数。而由进程#2的主线程去执行LoadService的onCreate()等函数。
  • LoadService在独立的进程(名称叫“remote”)里执行。于是, FirstActivity与LoadService之间就属于跨进程的沟通了。这种跨进程的沟通,就是大家熟知的IPC(Inter-Process Communication)机制了。这种IPC机制是透过底层驱动(Driver)来实现的。如下图:
  • 在 此 图 的 不 同 进 程 里 , 各 有 其 主 线 程(Thread)。 由于线程是不能越过进程边界的
    所以, 当执行LoadActivity的线程必须跨越进 程 去 执 行 LoadService( 的 函 数 ) 时 ,Android 的 内 层 Binder System 即 刻 从LoadService所在进程的线程池启动线程
    (BinderThread) 来 配 合 接 力 , 由 此BinderThread去执行LoadService。
     
練習: 绑定(Bind)远程的Service

请问:哪一个线程去执行下图的Service类呢?

请问:哪一个线程去执行下图的Service类呢?

  • Binder System會從進程的線程池(Thread pool)裡啟動一個線程來執行Binder::onTransact()函數。
     

请问:下图里各线程的关系是什么呢

  • Thread_a必须跨越进程去执行JavaBBinder对象时, Android的内层Binder System即刻从myService所在进程的线程池启动线程Thread_x来配合衔接Thread_a线程,由Thread_x去执行JavaBBinder对象。
  • Android的每一个进程里,通常含有一个线程池,让跨进程的线程得以进行。虽然是由Thread_a与Thread_x相互合作与衔接而完成远距通讯的,但让人们能单纯地认为是单一进程(即Thread_a)跨越到另一个进程去执行JavaBBinder对象。虽然JavaBBinder是C/C++层级的;而myService是Java层级的,两者不同语言,但处于同一个进程,所以Thread_x可以执
    行到myService对象。
     

http://www.ppmy.cn/server/156123.html

相关文章

芯片引脚缺陷检测数据集VOC+YOLO格式203张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;203 标注数量(xml文件个数)&#xff1a;203 标注数量(txt文件个数)&#xff1a;203 标注…

STM32 软件I2C读写

单片机学习&#xff01; 目录 前言 一、软件I2C读写代码框架 二、I2C初始化 三、六个时序基本单元 3.1 引脚操作的封装和改名 3.2 起始条件执行逻辑 3.3 终止条件执行逻辑 3.4 发送一个字节 3.5 接收一个字节 3.5 发送应答&接收应答 3.5.1 发送应答 3.5.2 接…

Tesseract5.4.0自定义LSTM训练

准备jTessBoxEditor&#xff0c;然后配置环境变量。 1、将图片转换成tif格式的&#xff0c;这里需要用画图工具另存为&#xff1b; 2、生成box文件 执行命令&#xff1a; tesseract agv.normal.exp1.tif agv.normal.exp1 -l eng --psm 6 batch.nochop makebox 关于box文件…

内部类 --- (寄生的哲学)

内部类总共有 4 种&#xff08;静态内部类、非静态内部类、局部内部类、匿名内部类&#xff09; 作用&#xff1a; 一&#xff1a;内部类提供了更好的封装&#xff0c;可以把内部类隐藏在外部类之内&#xff0c;不允许同一个包中的其他类访问该类。 二&#xff1a;内部类可以…

数据结构:循环单链表

循环单链表&#xff08;Circular Singly Linked List&#xff09; 循环单链表是单链表的一种变体&#xff0c;其特点是链表的尾节点指向头节点&#xff0c;形成一个闭环。这种结构允许在链表中进行无缝的遍历&#xff0c;并且可以从任何节点开始遍历整个链表。循环单链表通常用…

Spring Boot(快速上手)

Spring Boot 零、环境配置 1. 创建项目 2. 热部署 添加依赖&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional> </dependency&…

【pyqt】(二)基础框架

基础框架 qt的主要窗口有三种类型&#xff1a;QMainWindow、QWeidget、QDialog。 QMainWindow提供了一个包含菜单栏、工具栏、状态栏和中心部件的完整框架。QMainWindow 适合用作应用程序的主要窗口&#xff0c;特别是当需要复杂的用户界面布局时。QWeidget是轻量级的&#x…

Django 管理界面实现自动提交和动态字段选项

在开发 Django 项目时,我们经常需要自定义管理界面以提高数据输入的效率和用户体验。本文将介绍如何在 Django 管理界面中实现自动提交功能和动态字段选项,以满足复杂的数据管理需求。 背景 假设我们正在开发一个 ECS(Elastic Compute Service)服务管理系统。在这个系统中…