Android中AIDL和HIDL的区别

在Android中,AIDL(Android Interface Definition Language) 和 HIDL(HAL Interface Definition Language) 是两种用于定义跨进程通信接口的语言。AIDL 是 Android 系统最早支持的 IPC(进程间通信)机制,而 HIDL 是从 Android 8.0 开始引入,用于 HAL(Hardware Abstraction Layer)模块的接口定义。

随着 Android 的发展,Google 决定从 Android 11 开始将新的 HAL 统

一使用 AIDL 接口,而逐步放弃 HIDL。这种转变背后的原因涉及技术复杂度、性能、开发效率和生态统一性等多个方面。

1. AIDL 和 HIDL 的主要区别

1.1AIDL(Android Interface Definition Language)

用于 Android 系统中 App 层到 Framework 层之间的通信,也可以用于 Service 和 Client 的进程间通信。AIDL 使用 Binder 内核驱动程序进行调用。

AIDL 可以在 Android 中的任何进程之间使用:在平台组件之间使用或在应用之间使用均可。

他的主要的特点是:

  • 语言支持:支持 Java、C++ 和 Kotlin,最初主要服务于 App 层(Java 环境)。
  • 运行时绑定:通过 binder 驱动直接实现进程间通信,适合轻量的高频接口调用。
  • AIDL 文件编译:通过工具生成 Stub 和 Proxy 代码,封装了序列化和反序列化逻辑,开发者只需实现核心逻辑。

1.2 HIDL(Hardware Interface Definition Language)

HIDL 旨在用于进程间通信 (IPC)。使用 HDL 创建的 HAL 称为绑定式 HAL,因为它们可以使用 Binder 进程间通信 (IPC) 调用与其他架构层进行通信。绑定式 HAL 在独立于使用它们的客户端的进程中运行。对于必须与进程相关联的代码库,还可以使用透传模式(在 Java 中不受支持)。

HIDL 可指定数据结构和方法签名,这些内容会整理归类到接口(与类相似)中,而接口会汇集到软件包中。尽管 HIDL 具有一系列不同的关键字,但 C++ 和 Java程序员对 HIDL 的语法并不陌生。此外,HIDL 还使用 Java 样式的注解。

他的主要的特点是:

  • 使用场景:专为 HAL 设计,用于定义硬件抽象层和 Framework 层之间的接口。
  • 语言支持:主要支持 C++,不直接支持 Java。
  • 静态绑定:HIDL 在编译时生成接口代码,运行时通过 hwservicemanager 注册和发现服务。
  • 接口版本化:支持接口的向前兼容和向后兼容,可以在同一个系统中并存多个版本的 HAL 模块。
  • 复杂性:HIDL 引入了较复杂的构建工具链(如 HIDL 编译器)和运行时管理机制。

2. Google 放弃 HIDL,统一使用 AIDL 的原因

2.1 简化开发和维护

  • 减少学习成本:
    HIDL 的学习曲线较陡,开发者需要熟悉 HIDL 特有的语法和工具链,而 AIDL 更加简单直观,开发者容易上手。

  • 统一接口开发方式
    将 HAL 和应用层接口统一为 AIDL,减少了系统中不同接口定义语言的种类,便于开发者在不同层级使用相同的工具和模式。

2.2 降低系统复杂性

HIDL 的工具链和运行时机制引入了额外的复杂性,比如 hwservicemanager 和接口的版本化管理,而 AIDL 的实现相对简单,使用单一的 binder 机制即可满足需求。

2.3 性能优化

AIDL 在轻量通信场景下性能优于 HIDL:

  • 序列化和反序列化效率高:AIDL 的传输格式更加精简。
  • 运行时绑定更灵活:无需像 HIDL 那样依赖 hwservicemanager,可以减少通信开销。

对于大多数硬件接口调用场景,AIDL 的性能足以满足需求,HIDL 的版本管理和静态绑定机制显得多余。

2.4 推动 Kotlin 和 Rust 的生态

AIDL 逐步扩展了对 Kotlin 和 Rust 的支持(尤其是在安全性上),这是 Google 推动现代语言生态的重要一步。相比之下,HIDL 偏向 C++,缺乏对新语言的良好支持。

2.5 接口版本化的简化

尽管 HIDL 的多版本支持机制强大,但实际使用中却增加了维护成本。AIDL 的接口版本化从 Android 10 开始进行了改进,通过 stable AIDL 提供了更简洁的方式来处理接口的向前和向后兼容性问题。

3.举例说明

就拿音频举例,AIDL 实现与 HIDL 音频 HAL 实现之间的区别:

  • 在 AIDL 音频核心 HAL 中,引入了新的 IConfig 接口,替代了 HIDL HAL 中通过 XML 文件定义的系统级参数。这些参数现在由框架直接从 Core HAL 读取,而不再依赖供应商提供的配置文件。例如,用于显示给用户以便控制的环绕声格式列表,现由 IConfig.getSurroundSoundConfig 方法直接提供。
  • 在 AIDL 音效 HAL 中,原先在 HIDL 音效 HAL 的 XML 文件中定义的 effectProxy 相关逻辑已迁移到音频框架中。框架通过调用 IFactory.queryEffects 方法获取系统中所有效果实例的列表,并使用 IFactory.queryProcessing 方法查询所有效果处理信息。
  • 为了避免“设备”一词在描述音频设备类型时可能产生的歧义,HIDL 音频 HAL 中的 IDevice 接口在 AIDL 音频 HAL 中被重新命名为 IModule。
  • 此外,IPrimaryDevice 接口已被移除并由新的机制替代。现在,系统会将当前音频模式和屏幕旋转方向的更新发送到每个 IModule 实例。而涉及蓝牙同步音频连接(如 BT SCO)和免提配置文件(HFP)的参数,则由独立的 IBluetooth 接口管理。与电话相关的控制由专用的 ITelephony 接口提供支持。这两个接口的实例都可以通过 IModule 接口的主实例来获取。更多细节可参见核心 HAL 与相关功能的对比表。
  • 与此同时,为了避免冗余,AIDL 音频 HAL 中移除了 IDevicesFactory 接口。HAL 模块(即 IModule 的实例)现在直接以其名称在 Service Manager 中注册,例如 bluetooth 或 r_submix。唯一的例外是主模块(primary module),它仍然以 default 作为实例名称进行注册。

4.接口映射内容:

所有 HIDL 接口都在 android.hardware.audio@N.M 软件包中,其中 N.M 表示 Major.Minor 版本。所有 AIDL 接口都在 android.hardware.audio.core 软件包中。

HIDL API 接口和配置文件AIDL API接口
IDevicesFactory在 ServiceManager注册 IModule。
IDeviceIModule
IPrimaryDeviceITelephony / IBluetooth
IStream /IStreamIn / IStreamOutStreamDescriptor /IStreamIn / IStreamCommon / IStreamOut
audio_policy_configuration.xml / audio_policy_engine_configuration.xmlIConfig / IModule
可配置的音频政策文件在 Android 14 中使用HbL妥现。

在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从0开始的操作系统手搓教程23:构建输入子系统——实现键盘驱动1——热身驱动

目录 所以,键盘是如何工作的 说一说我们的8042 输出缓冲区寄存器 状态寄存器 控制寄存器 动手! 注册中断 简单整个键盘驱动 Reference ScanCode Table 我们下一步就是准备进一步完善我们系统的交互性。基于这个,我们想到的第一个可以…

【JavaEE】-- 多线程(初阶)4

文章目录 8.多线程案例8.1 单例模式8.1.1 饿汉模式8.1.2 懒汉模式 8.2 阻塞队列8.2.1 什么是阻塞队列8.2.2 生产者消费者模型8.2.3 标准库中的阻塞队列8.2.4 阻塞队列的应用场景8.2.4.1 消息队列 8.2.5 异步操作8.2.5 自定义实现阻塞队列8.2.6 阻塞队列--生产者消费者模型 8.3 …

用Python分割并高效处理PDF大文件

在处理大型PDF文件时,将它们分解成更小、更易于管理的块通常是有益的。这个过程称为分区,它可以提高处理效率,并使分析或操作文档变得更容易。在本文中,我们将讨论如何使用Python和为Unstructured.io库将PDF文件划分为更小的部分。…

Python——计算机网络

一.ip 1.ip的定义 IP是“Internet Protocol”的缩写,即“互联网协议”。它是用于计算机网络通信的基础协议之一,属于TCP/IP协议族中的网络层协议。IP协议的主要功能是负责将数据包从源主机传输到目标主机,并确保数据能够在复杂的网络环境中正…

【MySQL】事务|概念|如何回滚|基本特性|MySQL事务隔离性具体怎么实现的

目录 1.为啥引入 2.是啥 3.如何回滚(日志) 🔥4.面试题:谈谈事务的基本特性 (1)原子性 (2)一致性(收入和支出相匹配) (3)持久性…

deepseek 本地部署

deepseek 本地部署 纯新手教学,手把手5分钟带你在本地部署一个私有的deepseek,再也不用受网络影响。流畅使用deepseek!!! 如果不想看文章,指路:Deep seek R1本地部署 小白超详细教程 &#xff0…

⭐算法OJ⭐N-皇后问题 II【回溯剪枝】(C++实现)N-Queens II

⭐算法OJ⭐N-皇后问题【回溯剪枝】(C实现)N-Queens 问题描述 The n-queens puzzle is the problem of placing n n n queens on an n n n \times n nn chessboard such that no two queens attack each other. Given an integer n, return the num…

关联封号率降70%!2025最新IP隔离方案实操手册

高效运营安全防护,跨境卖家必看的风险规避指南 跨境账号管理的核心挑战:关联封号风险激增 2024年,随着全球电商平台对账号合规的审查日益严苛,“关联封号”已成为跨境卖家最头疼的问题之一。无论是同一IP登录多账号、员工操作失误…

pytest框架 核心知识的系统复习

1. pytest 介绍 是什么:Python 最流行的单元测试框架之一,支持复杂的功能测试和插件扩展。 优点: 语法简洁(用 assert 替代 self.assertEqual)。 自动发现测试用例。 丰富的插件生态(如失败重试、并发执…

搭建BOA服务器

BOA服务器是嵌入式常用的服务器类型,嵌入式程序作为后端时候如果想配合网页进行显示,利用BOA服务器搭建网络界面是不错的选择 首先下载boa官方安装包 Boa Webserver 下载后传输到Ubuntu随便文件夹,解压 tar -xvf boa-0.94.13.tar.gz 进入…

C# OPC DA获取DCS数据(提前配置DCOM)

OPC DA配置操作手册 配置完成后,访问远程ip,就能获取到服务 C#使用Interop.OPCAutomation采集OPC DA数据,支持订阅(数据变化)、单个读取、单个写入、断线重连

Ubuntu20.04搭建gerrit code review

一、环境准备 1. 安装 Java 环境‌ Gerrit 依赖 Java 运行环境(推荐 JDK 8): sudo apt install openjdk-11-jdk 验证安装: java -version ‌2. 安装 Git sudo apt install git ‌3. 可选依赖 数据库‌:Gerrit …

【FSM-3: 串行序列】

FSM-3:串行序列 1 Serial receiver FSM使用总结: 所有涉及输出的driver原则上用cur_sta;若是使用nxt_sta的相当于是提前一拍知道结果,所以对于输出必须要使用clocked reg,这样才能和cur_sta对应起来;描述声…

蓝桥杯 之 前缀和与查分

文章目录 题目求和棋盘挖矿 前缀和有利于快速求解 区间的和、异或值 、乘积等情况差分是前缀和的反操作 前缀和 一维前缀和: # 原始的数组num,下标从1到n n len(num) pre [0]*(n1) for i in range(n):pre[i1] pre[i] num[i] # 如果需要求解num[l] 到num[r] 的区…

国产化板卡设计原理图:2330-基于FMC接口的JFM7K325T PCIeX4 3U PXIe接口卡

基于FMC接口的JFM7K325T PCIeX4 3U PXIe接口卡 一、板卡概述 本板卡基于 FPGAJFM7K325T 芯片,pin_to_pin兼容FPGAXC7K410T-2FFG900 ,支持PCIeX8、64bit DDR3容量2GByte,HPC的FMC连接器,板卡支持PXIE标准协议,其中XJ3…

计算机视觉之dlib人脸关键点绘制及微笑测试

dlib人脸关键点绘制及微笑测试 目录 dlib人脸关键点绘制及微笑测试1 dlib人脸关键点1.1 dlib1.2 人脸关键点检测1.3 检测模型1.4 凸包1.5 笑容检测1.6 函数 2 人脸检测代码2.1 关键点绘制2.2 关键点连线2.3 微笑检测 1 dlib人脸关键点 1.1 dlib dlib 是一个强大的机器学习库&a…

一周学会Flask3 Python Web开发-SQLAlchemy连接Mysql数据库

锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili app.py下,我们先配置数据库连接,然后写一个简单sql测试。 连接配置,包括用户名&#xff…

blender看不到导入的模型

参考:blender 快捷键 常见问题_blender材质预览快捷键-CSDN博客 方法一:视图-裁剪起点,设置一个很大的值 方法二:选中所有对象,对齐视图-视图对齐活动项-选择一个视图

CES Asia 2025增设未来办公教育板块,科技变革再掀高潮

作为亚洲消费电子领域一年一度的行业盛会,CES Asia 2025(第七届亚洲消费电子技术贸易展)即将盛大启幕。今年展会规模再度升级,预计将吸引超过500家全球展商参展,专业观众人数有望突破10万。除了聚焦人工智能、物联网、…

【目标检测】【NeuralPS 2023】Gold-YOLO:通过收集与分发机制实现的高效目标检测器

Gold-YOLO: Efficient Object Detector via Gather-and-Distribute Mechanism Gold-YOLO:通过收集与分发机制实现的高效目标检测器 0.论文摘要 在过去的几年中,YOLO系列模型已成为实时目标检测领域的领先方法。许多研究通过修改架构、增强数…