HarmonyOS应用程序包概述

117 阅读2分钟

1、应用与应用程序包

  • 什么是应用?

    所谓应用泛指运行在设备操作系统上,为用户提供的服务的程序。例:手机桌面上安装的一个个应用,微信、支付宝等。

  • 什么是应用程序包?

    一个应用对应的软件包文件。HarmonyOS使用 .hap 格式作为应用程序包,包含了资源、代码。Android使用.apk格式作为应用程序包,包含了资源、代码、配置文件。

我们的操作系统为我们提供了安装、卸载、更新的管理机制。系统也帮助我们屏蔽了不同的芯片平台的差异(x86/ARM,32位/64位等)。开发者更多聚焦于应用功能的实现。

2、多Module设计机制

  • 支持模块化开发

    将不同功能特性按照模块划分和管理,每一个功能模块作为一个独立的Module进行开发,Module可独立编译运行。模块化、松耦合的应用管理方式有助于应用的开发、维护与扩展。

  • 支持多设备适配

    每个Module都会标注所支持的设备类型,有些Module支持全部的设备类型,有些Module只支持一种或者几种设备。在应用市场分发应用包时,根据设备类型做精准的筛选和匹配,将不同的包合理的组合和部署到对应的设备上。

3、Module类型

  • Ability类型的Module

    编译后会生成一个.hap文件,HAP(Harmony ability package)包,可独立运行,有以下两种类型:

    • entry类型的Module:

      应用的主模块,包含入口,编译后会生成entry类型的HAP。

    • feature类型的Module:

      应用的动态模块,编译后会生成feature类型的HAP。

  • Library类型的Module

    用于实现代码和资源的共享。同一个Library类型的Module可以被其他的Module多次引用。有以下两种类型:

    • Static Library:静态共享库。编译后会生成一个以.har为后缀的文件,HAR(Harmony Archive Package)。
    • Shared Library:动态共享库。编译后会生成一个以.hsp为后缀的文件,HSP(Harmony Shared Package)。

静态共享库HAR和动态共享库HSP的区别:

包类型编译和运行方式发布和引用方式
HAR代码和资源跟随使用方编译,如果有多个使用方,它们的编译产物中会存在多份相同拷贝。支持应用内引用,还可以独立打包发布,供其他应用引用。
HSP代码和资源可以独立编译,运行时在一个进程中代码也只会存在一份。应用内HSP只支持应用内引用。

HAR和HSP在APP包中的形态示意图:

https://p0-xtjj-private.juejin.cn/tos-cn-i-73owjymdk6/c305df4a3a9e49a792cc8b48e04b3d2e~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg6JOd5p6rQW15:q75.awebp?policy=eyJ2bSI6MywidWlkIjoiMjk0NjM0Njg5MDU2OTc5MCJ9&rk3s=e9ecf3d6&x-orig-authkey=f32326d3454f2ac7e96d3d06cdbb035152127018&x-orig-expires=1742093429&x-orig-sign=dpnHM3xiLcUlM%2BSw2Uu%2Fyhs9P%2FA%3D