HarmonyOS开发实战( Beta5版)AOT编译使用指南

AOT编译使用指南

  • AOT(Ahead Of Time)即预先编译,在程序运行前,预先编译成高性能机器码,让程序在首次运行就能通过执行高性能机器码获得性能收益

  • 方舟AOT编译器实现了PGO (Profile-Guided-Optimization)编译优化,即通过结合预先profiling的运行时类型等信息和静态类型信息,预先静态地生成高性能优化机器代码。

  • 在方舟AOT编译器中,记录预先profiling运行时类型等信息的文件称为ap(ark-profile)文件。

  • 对性能有高要求的开发者可以使用AOT编译提升应用运行性能。

使用约束

  • 当前仅支持Stage模型的ArkTS工程
  • 仅支持在64位的手机设备上运行
  • 仅支持Build Mode为release时使用,但暂不支持发布上架到应用市场时使用

前置操作

  • 打开ap采集开关(默认关闭。设备重启后,开关恢复默认状态)

    hdc shell param set ark.profile true

操作步骤

  • 步骤一  预热应用。运行应用,并进行对应的热点操作,系统会自动在设备侧生成ap文件。

  • 步骤二  使用hdc shell命令出发AOT编译,生成机器码文件

    • 输入如下命令,待命令返回后,表示编译完成

      复制代码
      hdc shell bm compile -m partial {bundleName}
      • 说明:以bundleNamecom.example.myapplication 为例,输入以下命令可触发AOT编译

        复制代码
        hdc shell bm compile -m partial com.example.myapplication
  • 步骤三  编译完成后,检查编译状态。只有该应用下所有module都编译成功,系统才认为该应用编译成功

    • 执行以下命令,通过aotCompileStatus字段查看该应用下每个module的编译状态
      • hdc shell bm dump -n {bundleName}

        • 说明:以bundleNamecom.example.myapplication 为例,输入以下命令可查看该应用下每个module的编译状态
          • hdc shell bm dump -n com.example.myapplication
      • aotCompileStatus 状态说明:

        状态值 意义 常见场景
        0 尚未进行AOT编译 没有生成ap文件,或待进行AOT编译
        1 AOT编译成功 AOT编译成功
        2 AOT编译失败 AOT编译器内部错误
  • 步骤四  应用编译成功后,重启应用。重启后会加载优化的机器码文件。

  • 步骤五  如不需要AOT编译模式,执行以下命令清除特定应用的AOT产物。 hdc shell bm compile -r {bundleName}

    • 说明:使用过程中如出现应用闪退,界面不一致,手机功耗异常增加等不稳定情况,可按照本步骤清除AOT产物

最后

小编在之前的鸿蒙系统扫盲中,有很多朋友给我留言,不同的角度的问了一些问题,我明显感觉到一点,那就是许多人参与鸿蒙开发,但是又不知道从哪里下手,因为资料太多,太杂,教授的人也多,无从选择。有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)文档用来跟着学习是非常有必要的。

为了确保高效学习,建议规划清晰的学习路线,涵盖以下关键阶段:


鸿蒙(HarmonyOS NEXT)最新学习路线

该路线图包含基础技能、就业必备技能、多媒体技术、六大电商APP、进阶高级技能、实战就业级设备开发,不仅补充了华为官网未涉及的解决方案

路线图适合人群:

IT开发人员: 想要拓展职业边界
零基础小白: 鸿蒙爱好者,希望从0到1学习,增加一项技能。
**技术提升/进阶跳槽:**发展瓶颈期,提升职场竞争力,快速掌握鸿蒙技术

2.视频学习教程+学习PDF文档

HarmonyOS Next 最新全套视频教程

纯血版鸿蒙全套学习文档(面试、文档、全套视频等)

​​

总结

参与鸿蒙开发,你要先认清适合你的方向,如果是想从事鸿蒙应用开发方向的话,可以参考本文的学习路径,简单来说就是:为了确保高效学习,建议规划清晰的学习路线

相关推荐
珑墨9 分钟前
【Turbo】使用介绍
前端
军军君0140 分钟前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9222 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
听麟2 小时前
HarmonyOS 6.0+ 智慧出行导航APP开发实战:离线地图与多设备位置协同落地
华为·wpf·harmonyos
打小就很皮...2 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
qq_177767372 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
wuhen_n2 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon3 小时前
理解vue中的ref
前端·javascript·vue.js
jin1233223 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931704 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos