Zygote进程通信为什么用Socket而不是Binder?

Zygote进程是Android系统中的一个特殊进程,它在系统启动时被创建,并负责孵化其他应用进程。它的主要作用是预加载和共享应用进程的资源,以提高应用启动的速度。

在Android系统中,常用的进程通信方式有以下几种:

  1. Intents:Intents是Android系统中用于在不同组件之间传递消息的一种机制。通过发送和接收Intents,不同进程之间可以进行简单的通信。

  2. Binder:Binder是Android系统中的一种进程间通信(IPC)机制,它基于C/S(Client/Server)模型。Binder提供了一种高效的跨进程通信方式,可以在不同进程之间传递复杂的数据结构。

  3. ContentProvider:ContentProvider是Android系统中用于实现进程间数据共享的一种机制。通过ContentProvider,一个进程可以将自己的数据暴露给其他进程,其他进程可以通过ContentResolver来访问这些数据。

  4. Socket:Socket是一种基于网络的进程间通信方式,它可以在不同设备之间进行通信。通过Socket,不同进程可以通过网络传输数据。

Zygote进程介绍

Zygote进程是Android系统中的一个特殊进程,它在系统启动时被创建,并负责孵化其他应用进程。它的主要作用是预加载常用的系统类和资源,以提高应用启动的速度。

在Android系统中,每个应用都运行在独立的进程中,这样可以保证应用之间的隔离性。然而,创建新进程需要消耗一定的时间和资源。为了减少应用启动的时间,Android引入了Zygote进程。

Zygote进程在系统启动时会先加载一些常用的系统类和资源,然后通过fork()系统调用创建新的应用进程。新的应用进程会继承Zygote进程的内存空间,从而避免了重新加载系统类和资源的开销。这样,应用进程的启动速度就会大大提高。

Zygote的创建和启动过程:

  1. 系统启动时,Linux内核会加载init进程,init进程是Android系统的第一个用户空间进程。
  2. init进程会读取init.rc文件,该文件定义了系统启动时需要执行的一系列操作。
  3. 在init.rc文件中,会有一条类似于"service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server"的命令。
  4. 这条命令会启动一个名为zygote的进程,该进程的可执行文件是app_process,位于/system/bin目录下。同时,命令中的参数"-Xzygote"表示以zygote作为进程名,“–zygote"表示以zygote的方式启动进程,”–start-system-server"表示启动系统服务。
  5. Zygote进程启动后,会先执行一些初始化操作,然后进入主循环等待创建其他应用进程的请求。
  6. 当有应用进程需要创建时,Zygote会fork出一个子进程,并通过socket与子进程进行通信。
  7. 子进程会继承Zygote进程的资源,包括虚拟机、类加载器等,从而加快应用进程的启动速度。
  8. 子进程会加载应用的主类,并调用其main方法,从而启动应用。

Socket通信介绍

Socket通信是一种常见的进程间通信方式,它基于网络套接字(Socket)来实现进程之间的数据传输。Socket通信可以在同一台计算机上的不同进程之间进行通信,也可以在不同计算机上的进程之间进行通信。

在Socket通信中,一个进程可以充当服务器(Server),另一个进程可以充当客户端(Client)。服务器进程通过创建一个Socket,并绑定到一个特定的网络地址和端口上,等待客户端的连接请求。客户端进程通过创建一个Socket,并指定服务器的地址和端口,向服务器发起连接请求。

一旦建立了连接,服务器和客户端之间就可以通过Socket进行数据的发送和接收。服务器可以同时处理多个客户端的请求,每个客户端都会被分配一个独立的Socket连接。

Socket通信可以使用不同的协议,如TCP(Transmission Control Protocol)和UDP(User Datagram Protocol)。TCP是一种可靠的、面向连接的协议,它提供了数据的可靠传输和流式传输。UDP是一种无连接的协议,它提供了数据的不可靠传输和数据报传输。

Binder机制介绍

Binder是Android操作系统中的一种进程间通信(IPC)机制。它是一种高效的、基于消息传递的IPC机制,用于在Android系统中不同进程之间进行通信。

Binder的核心是一个驱动程序,它负责在不同进程之间传递消息。在Android系统中,每个应用程序运行在独立的进程中,而Binder机制允许这些进程之间进行通信,以实现数据共享和功能调用。

Binder机制的基本原理是通过Binder驱动程序提供的接口,将消息从一个进程发送到另一个进程。每个进程都有一个Binder对象,用于接收和处理来自其他进程的消息。当一个进程想要与另一个进程通信时,它可以通过Binder对象发送消息,并等待接收方的响应。

在Android系统中,Binder机制被广泛应用于各种场景,例如Activity与Service之间的通信、进程间共享数据等。它提供了一种安全可靠的IPC机制,能够有效地解决进程间通信的问题。

Socket与Binder对比

Socket和Binder是Android系统中常用的通信机制,它们在实现方式和使用场景上有一些区别。

  1. 实现方式:

    • Socket是一种基于网络协议的通信机制,通过网络套接字实现进程间通信。它使用TCP或UDP协议进行数据传输,可以在不同设备或同一设备的不同进程之间进行通信。
    • Binder是一种基于内核驱动的进程间通信机制,它通过驱动程序实现进程间的数据传输。Binder使用C/S架构,包括服务端和客户端,通过Binder驱动在内核空间中进行通信。
  2. 使用场景:

    • Socket适用于网络通信场景,可以在不同设备或同一设备的不同进程之间进行通信。常见的应用包括网络传输、远程过程调用(RPC)等。
    • Binder适用于Android系统内部的进程间通信场景,主要用于应用程序组件之间的通信,如Activity与Service之间的通信、跨进程的数据共享等。
  3. 性能和安全性:

    • Socket通信的性能相对较高,但在跨设备通信时需要考虑网络延迟和带宽等因素。同时,Socket通信需要进行网络权限的申请和管理,可能存在一定的安全风险。
    • Binder通信的性能相对较低,但在同一设备内部的进程间通信时具有较高的效率。同时,Binder通信在Android系统中有较好的安全性,可以通过权限控制和进程隔离来保护系统的安全性。

综上所述,Socket适用于网络通信场景,而Binder适用于Android系统内部的进程间通信场景。在选择通信机制时,需要根据具体的应用场景和需求进行选择。

Zygote进程为什么用Socket而不是Binder?

  1. 先后时序问题: Binder驱动是早于init进程加载的。而init进程是安卓系统启动的第一个进程。安卓中一般使用的Binder引用,都是保存在ServiceManager进程中的,而如果想从ServiceManager中获取到对应的Binder引用,前提是需要注册。init进程是先创建ServiceManager,后创建Zygote进程的。虽然Zygote更晚创建,但是也不能保证Zygote进程去注册binder的时候,ServiceManager已经初始化好了。注册时间点无法保证,AMS无法获取到Zygote的binder引用。

  2. 多线程问题: Linux中fork进程是不推荐fork一个多线程的进程的,因为如果存在锁的情况下,会导致锁异常。而如果自身作为Binder机制的接收者,就会创建一个额外的线程来进行处理(发送者进程是无影响的)。所以,如果使用Binder机制,就会导致去fork一个多线程的进程。

  3. 效率问题: AMS和Zygote之间使用的LocalSocket,相对于网络Socket,减少了数据验证等环节,所以其实效率相对于正常的网络Socket会大幅的提升。虽然还是要经过两次拷贝,但是由于数据量并不大,所以其实影响并不明显。

  4. Binder拷贝问题: 如果使用Binder机制的话,从Zygote中fork出子进程会拷贝Zygote中Binder对象。从而多占用了一块无用的内存区域。而Binder对象不能释放。Binder的特殊性在于其是成对存在的,其分为Client端对象和Server端对象。假设我们使用Binder,如果要释放掉Server端Binder引用对象,就必须释放掉AMS中的Client端Binder对象,那这样就会导致AMS失去Binder从而无法正常向Zygote发送消息。而使用Socket通讯的话,fork出APP进程之后,APP进程会去主动的关闭掉这个Socket,从而释放这块区域。使用Binder会造成额外的内存占用。

Zygote处理Socket消息

当一个应用程序需要创建一个新的进程时,它会通过Socket与Zygote进程进行通信。具体来说,应用程序会向Zygote进程发送一个包含应用程序的包名、进程名和其他参数的消息。Zygote进程接收到这个消息后,会根据这些参数创建一个新的进程,并执行应用程序的入口函数。

Zygote进程处理socket消息的过程可以简单描述如下:

  1. Zygote进程创建一个Socket,并绑定到一个特定的端口上,等待应用程序的连接请求。
  2. 当一个应用程序需要创建新进程时,它会通过Socket连接到Zygote进程,并发送一个包含应用程序参数的消息。
  3. Zygote进程接收到消息后,解析参数,并根据参数创建一个新的进程。
  4. Zygote进程将新进程的PID返回给应用程序,以便应用程序可以与新进程进行通信。

需要注意的是,Zygote进程并不直接处理Socket消息的具体内容,而是将消息传递给相应的处理函数来完成进程创建的工作。这些处理函数会根据消息中的参数来执行相应的操作,例如加载应用程序的代码、创建进程的环境等。

Zygote进程通过Socket与应用程序进行通信,接收应用程序的参数,并根据这些参数创建新的进程。这种机制使得Android系统能够高效地创建和管理大量的应用程序进程。

如果你还没有掌握Zygote,现在想要在最短的时间里吃透它,可以参考一下《Android Framework核心知识点》,里面内容包含了:Init、Zygote、SystemServer、Binder、Handler、AMS、PMS、Launcher……等知识点记录。

《Framework 核心知识点汇总手册》:https://qr18.cn/AQpN4J

Handler 机制实现原理部分:
1.宏观理论分析与Message源码分析
2.MessageQueue的源码分析
3.Looper的源码分析
4.handler的源码分析
5.总结

Binder 原理:
1.学习Binder前必须要了解的知识点
2.ServiceManager中的Binder机制
3.系统服务的注册过程
4.ServiceManager的启动过程
5.系统服务的获取过程
6.Java Binder的初始化
7.Java Binder中系统服务的注册过程

Zygote :

  1. Android系统的启动过程及Zygote的启动过程
  2. 应用进程的启动过程

AMS源码分析 :

  1. Activity生命周期管理
  2. onActivityResult执行过程
  3. AMS中Activity栈管理详解

深入PMS源码:

1.PMS的启动过程和执行流程
2.APK的安装和卸载源码分析
3.PMS中intent-filter的匹配架构

WMS:
1.WMS的诞生
2.WMS的重要成员和Window的添加过程
3.Window的删除过程

《Android Framework学习手册》:https://qr18.cn/AQpN4J

  1. 开机Init 进程
  2. 开机启动 Zygote 进程
  3. 开机启动 SystemServer 进程
  4. Binder 驱动
  5. AMS 的启动过程
  6. PMS 的启动过程
  7. Launcher 的启动过程
  8. Android 四大组件
  9. Android 系统服务 - Input 事件的分发过程
  10. Android 底层渲染 - 屏幕刷新机制源码分析
  11. Android 源码分析实战

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/115375.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ABAP简单的队列设置QRFC

场景:用job的方式在接口里启用job,如果接口调用比较频繁,存在同一时间启动相同job的情况,会导致锁表锁程序这种情况。 查阅job函数,发现在JOB_CLOSE函数里自带了类似队列的参数,但是因为是接口&#xff0c…

文件夹还在,里面文件没了?问题这样解决

文件夹还在但文件无故消失怎么办?文件的消失对于我们来说可能是个令人沮丧且困惑的问题。有时候,我们可能会发现文件夹依然存在,但其中的文件却消失了。在这篇文章中,我们将探讨为什么电脑文件会无故消失的原因,并提供…

这个超实用的门禁技巧,让办公楼安全更简单高效!

门禁监控是现代社会中不可或缺的一部分,用于确保安全和管理进出某个区域的人员。随着科技的不断发展,门禁监控已经远离了传统的机械锁和钥匙,变得更加智能化和高效。 客户案例 企业办公大楼 无锡某大型企业在其办公大楼内部部署了泛地缘科技…

ChatGLM3设置角色和工具调用的解决方案

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…

SpringMVC简单介绍与使用

目录 一、SpringMVC介绍 二、SpringMVC作用 三、SpringMVC核心组件 四、SpringMVC快速体验 一、SpringMVC介绍 Spring Web MVC是基于Servlet API构建的原始Web框架,从一开始就包含在Spring Framework中。正式名称“Spring Web MVC”来自其源模块的名称&#xff…

Node.js 中解析 HTML 的方法介绍

在 Web 开发中,解析 HTML 是一个常见的任务,特别是当我们需要从网页中提取数据或操作 DOM 时。掌握 Node.js 中解析 HTML 的各种方式,可以大大提高我们提取和处理网页数据的效率。本文将介绍如何在 Node.js 中解析 HTML。 基本概念 HTML 解析…

MySQL第三讲·SQL boy的CRUD操作

你好,我是安然无虞。 文章目录 增删查改:如何操作表中的数据?添加数据插入数据记录插入查询结果 删除数据修改数据查询数据select|where|group by|havingfromorder bylimit 增删查改:如何操作表…

第G7周:Semi-Supervised GAN 理论与实战

🍨 本文为🔗365天深度学习训练营 中的学习记录博客 🍦 参考文章:365天深度学习训练营-第G7周:Semi-Supervised GAN 理论与实战(训练营内部成员可读) 🍖 原作者:K同学啊|接…

【蓝桥杯选拔赛真题44】python小蓝晨跑 青少年组蓝桥杯python 选拔赛STEMA比赛真题解析

目录 python小蓝晨跑 一、题目要求 1、编程实现 2、输入输出 二、算法分析

作为一个初学者,该如何入门大模型?

在生成式 AI 盛行的当下,你是否被这种技术所折服,例如输入一段简简单单的文字,转眼之间,一幅精美的图片,又或者是文笔流畅的文字就展现在你的面前。 相信很多人有这种想法,认为生成式 AI 深不可测&#xf…

系列十五、idea全局配置

一、全局Maven配置 IDEA启动页面>Customize>All settings>Build,Execution,Deployment>Build Tools>Maven 二、全局编码配置 IDEA启动页面>Customize>All settings>Editor>File Encodings 三、全局激活DevTools配置 IDEA启动页面>Customize>A…

ASTM F963-23美国玩具安全新标准发布

新标准发布 2023年10月13日,美国材料与试验协会(ASTM)发布了新版玩具安全标准ASTM F963-23。 主要更新内容 与ASTM F963-17相比,此次更新包括:单独描述了基材重金属元素的豁免情况,更新了邻苯二甲酸酯的管控…

表格冻结第二行

在网上找了一圈也没找到说明白的。 像这样的表格下面会有很多行,往下翻的时候会忘记第二行显示的什么内容。 需求:将第二行进行冻结 实现: 1,选中第一和第二行,下拉,点击冻结 2,会显示冻结至…

MinIO多容器配置NGINX代理实践(docker-compose版本)

以下nginx配置 分别将本机的9001端口代理到minio1,minio2,minio3,minio4主机的9001端口。用于minio后台 分别将本机的9000端口代理到minio1,minio2,minio3,minio4主机的9000端口。用于minioApi events {worker_connections 1024; }http {upstream minio_console {server min…

kubernetes集群编排——k8s存储

configmap 字面值创建 kubectl create configmap my-config --from-literalkey1config1 --from-literalkey2config2kubectl get cmkubectl describe cm my-config 通过文件创建 kubectl create configmap my-config-2 --from-file/etc/resolv.confkubectl describe cm my-confi…

研发效能DevOps: Git安装

目录 一、理论 1.Git 2.Git 工具 二、实验 1.Git安装 2.配置Git 3. VS Code加载Git 一、理论 1.Git (1)简介 Git 是一个分布式版本控制及源代码管理工具;Git 可以为你的项目保存若干快照,以此来对整个项目进行版本管理。 Git 是一个…

如何做好网页配色,分享一些配色方案和方法

很多网页设计师在选择网页配色方案时,会纠结于用什么网页UI配色方案来吸引客户的注意力,传达信息。选择正确的颜色是网页设计不可或缺的一部分。本指南将从色彩理论和色彩心理学入手,分享三个网页UI配色的简单步骤。 网页UI配色方法有很多&a…

会声会影2024出来了吗?有哪些新功能?剪辑后音乐剪辑教程

会声会影 2024视频编辑软件,既加入光影、动态特效的滤镜效果,也提供了与色彩调整相关的LUT配置文件滤镜,可选择性大,运用起来更显灵活。会声会影在用户的陪伴下走过20余载,经过上百个版本的优化迭代,已将操…

使用 Python 进行自然语言处理第 4 部分:文本表示

一、说明 本文是在 2023 年 3 月为 WomenWhoCode 数据科学跟踪活动发表的系列文章中。早期的文章位于:第 1 部分(涵盖 NLP 简介)、第 2 部分(涵盖 NLTK 和 SpaCy 库)、第 2 部分(涵盖NLTK和SpaCy库&#xf…

open mp笔记

Open mp在cpu上并行计算, 统一内存访问(OPEN MP pthreads),同一块内存共享多个CPU 非统一内存访问(MPI),每个CPU都有自己对应的内存,通过blus interconnect链接起来,cpu不能直接访问他们的内存,…
最新文章