内容简介:理解 Flutter 编译产物之前需要理解 Flutter 的编译模式。 任何语言在运行之前都需要编译,常见的编译模式如 JIT 和 AOT。JIT 可以在运行时即时编译,优势是可以动态下发和执行代码,劣势也是对应的会影响设备运行速度。AOT 即提前编译生成类 C 的二进制代码,优势是可以较快速度生成和执行平台代码,劣势就是需要提前知道对应平台的架构,甚至要为不同平台架构生成不同的代码。Flutter 在代码编写阶段(Debug)是采用 JIT 方式编译代码,所有相关的 Dart 代码编译之后打包在 AP
理解 Flutter 编译产物之前需要理解 Flutter 的编译模式。 任何语言在运行之前都需要编译,常见的编译模式如 JIT 和 AOT。JIT 可以在运行时即时编译,优势是可以动态下发和执行代码,劣势也是对应的会影响设备运行速度。AOT 即提前编译生成类 C 的二进制代码,优势是可以较快速度生成和执行平台代码,劣势就是需要提前知道对应平台的架构,甚至要为不同平台架构生成不同的代码。
JIT 编译后产物
Flutter 在代码编写阶段(Debug)是采用 JIT 方式编译代码,所有相关的 Dart 代码编译之后打包在 APK 下的 assets 目录下,是由对应的 libs 目录下的 .so 库中虚拟机执行。
libs 目录下对应的不同架构平台的 Flutter 执行虚拟机;
另外 assets 目录下 kernel_blob.bin 是 Flutter 引擎的底层接口和 Dart 语言基本功能部分代码;
platform.dill 则是实现了 Flutter 页面逻辑的代码,也包括 Flutter Framework 和其他由 pub 依赖的库代码,和 Dart VM 相关的 kernel 代码,仅和 Dart 版本以及 engine 编译版本有关。固定。
AOT 编译后产物
Flutter 在 Release 模式下关闭了所有调试信息和断言,包的大小都做了优化。
FLutter 在 Release 模式下采用 AOT 模式,solate_snapshot_data、vm_snapshot_data、isolate_snapshot_instr、vm_snapshot_instr。对比 JIT 模式下,不认识的产物有:isolate_snapshot_instr 和 vm_snapshot_instr,其实它俩代表着 VM 和 isolate 启动后所承载的指令等数据。在载入后,直接将该块内存执行即可;
snapshot 文件由 Flutter SDK 中的 flutter/bin/cache/artifacts/engine/android-arm-release/darwin-x64/gen_snapshot 命令生成,vmsnapshot* 是 Dart 虚拟机运行所需要的数据和代码指令,isolatesnapshot* 则是每个 isolate 运行所需要的数据和代码指令。
理解 Flutter 编译产物的性质,有助于我们更加方便的集成 Flutter/Dart 运行时或者 Debug 时所需要的依赖到现有 Android / iOS 工程中,从而更加方便的模块化开发。
以上所述就是小编给大家介绍的《Flutter 编译产物的理解》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Gradle Builds Everything:产物输出
- 实战第四步:新项目之十大输出产物
- JB的测试之旅-jenkins打包产物生成二维码
- Xcode 编译疾如风系列(二):并行编译
- 编写 MSBuild 内联编译任务(Task)用于获取当前编译环境下的所有编译目标(Target)
- 使用 Visual Studio 编译时,让错误一开始发生时就停止编译(以便及早排查编译错误节省时间)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。