Flutter 打包APK的几种方式

前言

Flutter打包不同于RN,Flutter可以在Android Studio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式。

通过本篇文章,你将了解到:

  1. Android原生打包APK方式
  2. Flutter通过原生工程打包方式
  3. Futter工程打包方式
  4. Flutter打包产物分析

1. Android原生打包APK方式

以原生Android工程为例。

  1. 设置编译模式


选择变体,通常有debug和release模式(可以新增不同的模式),默认是debug模式。
我们平时点击Run到设备上就是debug模式。

  1. 开始构建


选择后开始构建,因为前面选的是debug模式,因此此时打出来的包就是debug包。

  1. 查看构建产物


可以看出,build目录下有个debug.apk,说明打包成功。

当然如果要打release包,首先要在build.gradle(module级别)设置签名,而后再按上述的步骤将Build Variant 切换成release模式,接下来的操作与debug模式打包一样的。

release产物如下:
此处没有设置签名,因此打出来的包有unsigned字样。

2. Flutter通过原生工程打包方式

打开一个Flutter工程,其目录结构如下:
可以看出,根目录下有个android的目录,使用Android Studio 打开该目录:

这就是一个可正常运行的Android 工程,在此处运行与在Flutter 工程里运行效果是一致的。
只不过Build Variant比普通的Android工程多了个profile模式(性能调试时使用,平时用不到)。

因此打开Flutter里的android工程,就可以像普通android工程一样构建、打包。

3. Futter工程打包方式

当然如果你不想既打开Flutter工程,又打开Android工程,其实Flutter工程里也可以编译打包的,归纳为三种方式。

第一种:

查看产物:


注意:

此种方式默认是release模式

第二种:

命令行打包,在Android Studio Terminal里输入如下命令

flutter build apk --debug //打debug包

flutter build apk --release //打release包

打包的产物依旧是如上flutter-apk目录。

第三种:

如果嫌每次命令行输入命令麻烦,而只想将包run在设备上,此时依然可以借助IDE。

编辑配置。

填上"--debug"表示run的是debug包。

同样的,填上"--release"表示run的是release包。

最终配置界面显示如下:

此时即可随时run不同模式的包。

4. Flutter打包产物分析

debug、release模式下,Flutter业务代码分别以什么样的形式存在呢?

解压apk,查看debug模式下的产物:

以.bin文件存在,支持JIT(Just-In-Time),有调试信息,支持热重载。

JIT:

定义: JIT 是一种动态编译技术,在运行时将代码从高级语言(如 Dart)即时编译为机器码。

用途:

主要用于开发阶段,支持热重载(Hot Reload)功能。

允许开发者快速查看代码更改的效果,而无需重新启动应用。

特点:

不需要提前编译整个应用程序。

运行速度较慢,因为编译是在运行时完成的。

占用更多内存,适合开发环境而非生产环境

解压,查看release模式下的产物:

最终是打包为了.so文件,支持AOT (Ahead-Of-Time )。 AOT :

定义: AOT 是一种静态编译技术,在构建阶段将代码从高级语言(如 Dart)提前编译为原生机器码。

用途:

主要用于生产环境,确保应用性能最优。

编译后的代码可以直接运行在目标设备上,无需额外的虚拟机或解释器。

特点:

提供更快的应用启动时间和运行速度。

减少内存占用。

不支持热重载,但生成的二进制文件更小、更高效

相关推荐
&Sinnt&31 分钟前
Git 版本控制完全指南:从入门到精通
git·后端
coder_pig40 分钟前
跟🤡杰哥一起学Flutter (三十四、玩转Flutter手势✋)
前端·flutter·harmonyos
万少1 小时前
01-自然壁纸实战教程-免费开放啦
前端
独立开阀者_FwtCoder1 小时前
【Augment】 Augment技巧之 Rewrite Prompt(重写提示) 有神奇的魔法
前端·javascript·github
yuki_uix1 小时前
AI辅助网页设计:从图片到代码的实践探索
前端
我想说一句1 小时前
事件机制与委托:从冒泡捕获到高效编程的奇妙之旅
前端·javascript
陈随易1 小时前
MoonBit助力前端开发,加密&性能两不误,斐波那契测试提高3-4倍
前端·后端·程序员
wfsm1 小时前
spring事件使用
java·后端·spring
小飞悟1 小时前
你以为 React 的事件很简单?错了,它暗藏玄机!
前端·javascript·面试
中微子1 小时前
JavaScript 事件机制:捕获、冒泡与事件委托详解
前端·javascript