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

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 源码分析实战

相关文章:

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

Zygote进程是Android系统中的一个特殊进程,它在系统启动时被创建,并负责孵化其他应用进程。它的主要作用是预加载和共享应用进程的资源,以提高应用启动的速度。 在Android系统中,常用的进程通信方式有以下几种: Intent…...

API接口加密,解决自动化中登录问题

一、加密方式 AES:对称加密,快RAS:非对称加密,慢AESRAS:安全高效 加密过程:字符串》字节流》加密的字节流(算法),解密有可能出现乱码,所以不能直接转成字符…...

COCOS2DX3.17.2 Android升级targetSDK30问题解决方案

一、luajit不兼容问题 不兼容版本:【2.1.0-bate2、2.1.0-bate3都存在异常】 出问题系统:Android11;Android10的系统部分机型有问题,部分机型正常 异常点1:c调用lua接口,pushObjiect的时候crash 异常点2…...

HarmonyOS鸿蒙原生应用开发设计- 隐私声明

HarmonyOS设计文档中,为大家提供了独特的隐私声明,开发者可以根据需要直接引用。 开发者直接使用官方提供的隐私声明内容,既可以符合HarmonyOS原生应用的开发上架运营规范,又可以防止使用别人的内容产生的侵权意外情况等&#xff…...

【面试精选】00后卷王带你三天刷完软件测试面试八股文

前言 本人普通本科计算机专业,做测试也有3年的时间了,讲下我的经历,我刚毕业就进了一个小自研薪资还不错,有10.5k(个人觉得我很优秀),在里面呆了两年,积累了一些的经验和技能&#…...

k-means算法c++实现

计算数据集中的元素与各个簇的中心的距离&#xff0c;将它赋给最近的簇&#xff0c;然后重新计算每个簇的平均值&#xff0c;再将元素按离平均值点最近的原则重新分配直到没有出现重新分配 该算法要事先给出k的值&#xff0c;即划分为几个簇。 vector<int> datoclu(dat…...

oracle查询哪些用户下有表

oracle查询哪些用户下有表,排除系统用户。 在实际业务中 oracle数据库中创建了很多的用户 但实际都是无表的,利用SQL语句将这些有表的用户查询出来 并显示用户名、表名、创建表的时间等信息。 select * from dba_objects where object_type = TABLE and owner not in ( AN…...

机器人连杆惯量参数辨识(估计)

杆的转动惯量的计算公式是Imr^2。在经典力学中&#xff0c;转动惯量&#xff08;又称质量惯性矩&#xff0c;简称惯矩&#xff09;通常以I 或J表示&#xff0c;SI 单位为 kgm。对于一个质点&#xff0c;I mr&#xff0c;其中 m 是其质量&#xff0c;r 是质点和转轴的垂直距离。…...

一座 “数智桥梁”,华为助力“天堑变通途”

《水调歌头游泳》中的一句话&#xff0c;“一桥飞架南北&#xff0c;天堑变通途”&#xff0c;广为人们所熟知&#xff0c;其中展现出的&#xff0c;是中国人对美好出行的无限向往。 天堑变通途从来不易。 中国是当今世界上交通运输最繁忙、最快捷的国家之一&#xff0c;交通行…...

C#知识总结 基础篇(上)

本篇内容参考C#图解教程 本篇内容偏向基础&#xff0c;适合0基础的朋友快速上手&#xff0c;也适合有一定C语言&#xff08;或其他语言如C,java&#xff09;基础的人快速上手C#。同时适合unity引擎的初学者&#xff0c;更加详细的了解C#语言。 本文内容基本涵盖C#基础内容&am…...

照片编辑软件Affinity Photo 2 for Mac v2.1.1中文激活版 2024年最新中文版下载

照片编辑软件Affinity Photo 2 for Mac v2.1.1中文激活版是一款功能强大的专业级图像编辑软件&#xff0c;由Serif公司开发。它提供了广泛的工具和功能&#xff0c;适用于摄影师、设计师和艺术家。 照片编辑软件Affinity Photo 2 for Mac v2.1.1中文激活版软件介绍 TIFF&#…...

TPAMI 2023 | Temporal Perceiver:通用时序边界检测方法

本文介绍一下今年我们组被T-PAMI 2023收录的时序边界检测工作 Temporal Perceiver: A General Architecture for Arbitrary Boundary Detection。​​​​​​​ 论文名称&#xff1a; Temporal Perceiver: A General Architecture for Arbitrary Boundary Detection 论文链接&…...

Unity-UV展开工具

using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEditor;public class unfold : EditorWindow {[MenuItem("Gq_Tools/展开")]public static void ShowWin(){EditorWindow.CreateInstance<unfold>().Show();}priva…...

springboot actuator jvm监控丢失

1、背景 系统接入了监控prometheus和grafana&#xff0c;某天grafana突然发现只有几台机器可以看到指标。 随便点击一个地址http://192.168.0.76:8681/lms/actuator/prometheus访问指标&#xff0c;发现JVM相关指标全部丢失 2、解决方法 从网上查找相关资料&#xff0c;逐一…...

UDP服务端和客户端通信代码开发流程

一、UDP通信 TCP&#xff1a;传输控制协议&#xff0c;面向连接的&#xff0c;稳定的&#xff0c;可靠的&#xff0c;安全的数据集流传递 稳定和可靠:丢包重传 数据有序:序号和确认序号 流量控制:稳定窗口 UDP&#xff1a;用户数据报协议 面向无连接的,不稳定的,不可靠,不安…...

数据库实验:SQL的数据定义与单表查询

目录 实验目的实验内容实验要求实验过程实验步骤实例代码结果示意 数据库的实验&#xff0c;对关系型数据库MySQL进行一些实际的操作 实验目的 (1) 掌握DBMS的数据定义功能 (2) 掌握SQL语言的数据定义语句 (3) 掌握RDBMS的数据单表查询功能 (4) 掌握SQL语言的数据单表查询语句…...

P3398 仓鼠找 sugar

Portal. LCA。 询问树上两条路径是否有交点。 画图发现无非两种情况&#xff1a; 发现一条路径的起点和终点的 LCA 经过另一条路径&#xff0c;是两路径相交的充要条件。 考虑如何判断这个 LCA 在不在路径上。若 d ( s , LCA ) d ( LCA , t ) d ( s , t ) d(s,\text{LCA…...

C# 发送邮件

1.安装 NuGet 包 2.代码如下 SendMailUtil using MimeKit; using Srm.CMER.Application.Contracts.CmerInfo; namespace Srm.Mail { public class SendMailUtil { public async static Task<string> SendEmail(SendEmialDto sendEmialDto,List<strin…...

Zeal下载文档慢的问题

1. 安装Zeal 官方下载网站&#xff1a; https://zealdocs.org/ 2. 安装文档&#xff08;在线安装方式&#xff09;&#xff08;下载速度非常慢&#xff09; Tools - Docsets Available中下载安装对应的文档 3. 安装文档&#xff08;离线安装方式&#xff09; ①下载文档…...

HR模块开发(1):简单的开发流程和注意事项

HR模块开发 一、模块概述 人力资源管理解决方案关注3个领域:每位雇员都发展和维护着‘公司内’和‘公司外’的种种‘关系’。运用科技,强化这些关系,可以提高忠诚度和生产力,公司整体得到商业价值。 员工关系管理员工职业生命周期管理员工事务处理管理HR模块的基本知识和构…...

创建Vue实例

我们已经知道了Vue框架可以 基于数据帮助我们渲染出用户界面&#xff0c;那应该怎么做呢&#xff1f; 核心步骤&#xff08;4步&#xff09;&#xff1a; 准备容器 引包&#xff08;官网&#xff09; — 开发版本/生产版本 创建Vue实例 new Vue() 指定配置项&#xff0c;渲…...

2024上海国际人工智能展(CSITF)以“技术,让生活更精彩”为核心理念,以“创新驱动发展,保护知识产权,促进技术贸易”为主题

2024上海国际人工智能展&#xff08;CSITF&#xff09; China&#xff08;Shanghai&#xff09;International Technology Fair 时间:2024年6月12-14日 地点:上海世博展览馆 主办单位 中华人民共和国商务部 中华人民共和国科学技术部 中华人民共和国国家知识产权局 上海市…...

Vue3使用Monaco-editor

Monaco-editor&#xff0c;一个vs code 编辑器&#xff0c;需要将其集成到项目。不说闲话了&#xff0c;直接上代码。 npm地址&#xff1a;https://www.npmjs.com/package/monaco-editor 中文文档&#xff1a;https://aydk.site/editor/ 安装&#xff1a; pnpm add monaco…...

java 根据ip获取到城市 GeoLite2-City.mmdb

本文可解决 根据ip定位获取不到问题&#xff0c;提供多种方式仅供参考&#xff1a; 1.选型 1.1 实现方式 Java可以实现IP地址解析和省市区信息查询&#xff0c;但是需要借助一些外部数据源或数据库来实现。常用的方法有以下几种&#xff1a; 1.1.1 本地文件解析 可以通过下…...

kaggle使用说明

kaggle kaggle使用参考1、kaggle目录2、kaggle上传本地文件后&#xff0c;如何不改代码就可运行3、已上传文件的修改3.1 重新上传3.2 重写文件 4、创建文件夹5、结果下载5.1 多文件&#xff1a;先打包再下载5.2 重定文件下载链接 kaggle使用参考 Kaggle 新手入门必看&#xff…...

BUUCTF FLAG 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 注意&#xff1a;请将 hctf 替换为 flag 提交&#xff0c;格式 flag{} 密文&#xff1a; 下载附件&#xff0c;得到一张.png图片。 解题思路&#xff1a; 1、因为附件是一张图片&#xff0c;先放到StegSolve中&…...

万物皆可“云” 从杭州云栖大会看数智生活的未来

文章目录 前言一、云栖渐进&#xff1a;一个科技论坛的变迁与互联网历史互联网创新创业飞天进化飞天智能驱动数字中国 二、2023云栖大会&#xff1a;云计算人工智能 玩出科技跨界新花样大会亮点重磅嘉宾热门展览算力馆人工智能馆产业创新馆 总结 前言 10月31日&#xff0c;202…...

LeetCode1518 换水问题

题目描述 超市正在促销&#xff0c;你可以用 numExchange 个空水瓶从超市兑换一瓶水。最开始&#xff0c;你一共购入了 numBottles 瓶水。 如果喝掉了水瓶中的水&#xff0c;那么水瓶就会变成空的。 给你两个整数 numBottles 和 numExchange &#xff0c;返回你 最多 可以喝…...

强大日志查看器,助力数据联动分析

前言 我们曾讨论过观测云查看器强大的查询筛选和搜索功能&#xff0c;能够帮助用户快速、精准地检索数据&#xff0c;定位故障问题&#xff08;参见《如何使用查看器筛选、搜索功能进行数据定位&#xff1f;》&#xff09;。除此之外&#xff0c;日志查看器不仅可以帮助我们收…...

HIBS一些简介

文章目录 距离发展&#xff1a;意义使用挑战安全IOT活动服务频带可行性频谱 距离 海拔约20KM的平流层中&#xff0c;国际电联无线电条例&#xff08;RR&#xff09;将HAPS定义为位于20-50公里高度和相对于地球的指定标称固定点的物体上的无线电台。 #高空平台作为IMT基站(HIB…...