Android Studio 中 build、assemble、assembleDebug 和 assembleRelease 构建 aar 的区别

上一篇:Tasks中没有build选项的解决办法

概述:

在构建 aar 包时通常会在下面的选项中进行构建,但是对于如何构建,选择哪种方式构建我还是处于懵逼状态,所以我整理了一下几种构建方式的区别以及如何选择。

1. build(位于 build 分组下)

build 会同时执行 assemble + check(包含 lint 检查等),速度较慢,且通常不需要额外检查步骤。

2. assemble(位于 build 分组下)

作用
  • 构建所有变体(Variants) :包括 Debug、Release 以及其他自定义构建类型(如 Staging)和产品风味(Product Flavors)的组合。
  • 生成所有可能的 AAR/APK :例如,如果你有 freepaid 两种产品风味,assemble 会生成:
    • freeDebugfreeRelease
    • paidDebugpaidRelease
使用场景
  • 需要一次性构建所有变体(如 CI/CD 环境打包全部分发版本)。
  • 不关心具体构建类型时(但会显著增加构建时间)。
输出路径
复制代码
/build/outputs/aar/
  ├── module-name-free-debug.aar
  ├── module-name-free-release.aar
  ├── module-name-paid-debug.aar
  └── module-name-paid-release.aar

3. assembleDebug / assembleRelease(位于 other 分组下)

作用
  • 针对单一构建类型
    • assembleDebug:仅构建 Debug 版本(未优化,含调试符号)。
    • assembleRelease:仅构建 Release 版本(经过 ProGuard 优化,无调试信息)。
使用场景
  • 日常开发中快速生成 Debug 版 AAR 供测试。
  • 发布时明确需要 Release 版 AAR(优化后的正式版本)。
输出路径
复制代码
/build/outputs/aar/
  ├── module-name-debug.aar    # assembleDebug
  └── module-name-release.aar  # assembleRelease

4. 关键区别

Task 构建范围 构建速度 典型用途
assemble 所有变体(Debug+Release+Flavors) 全量构建(如 CI 打包所有版本)
assembleDebug 仅 Debug 版本 开发调试
assembleRelease 仅 Release 版本 中等 正式发布或分发给第三方

5. 为什么 assembleDebug/Releaseother 分组?

  • 历史原因 :Gradle 将"非标准"任务归类到 other,而 assemble 是通用聚合任务。
  • 实际无影响:分组仅是 UI 展示逻辑,功能完全正常。

6. 如何选择?

推荐方式

使用 assembleRelease (生成 Release 版 AAR)或 assembleDebug(生成 Debug 版 AAR):

  • 路径 :Gradle → 模块名otherTasksbuildassembleRelease/assembleDebug

  • 生成位置

    复制代码
    /module-name/build/outputs/aar/module-name-release.aar  
    /module-name/build/outputs/aar/module-name-debug.aar
不推荐直接使用 build Task
  • build 会同时执行 assemble + check(包含 lint 检查等),速度较慢,且通常不需要额外检查步骤。
  • 如果只是需要 AAR,直接运行 assembleRelease 更高效。

总结

  • 开发阶段 :用 assembleDebug(快速生成调试版)。
  • 发布阶段 :用 assembleRelease(生成优化后的正式版)。
  • 批量构建 :用 assemble(但通常仅在自动化流程中使用)。
相关推荐
王泰虎1 小时前
安卓开发日记,因为JCenter 关闭导致加载不了三方库应该怎么办
android
weixin_660096784 小时前
如何关闭vscode中的copilot生成结束后的消息提醒
ide·vscode·copilot
2601_949543015 小时前
Flutter for OpenHarmony垃圾分类指南App实战:主题配置实现
android·flutter
玄同7655 小时前
Trae国际版与国内版深度测评:AI原生IDE的双生花
ide·人工智能·ai编程·cursor·ai-native·trae
Jackson@ML5 小时前
[Kimi重磅出击!]用Kimi Code智能高效开发Web应用程序指南
ide·python·kimi code
2601_949833396 小时前
flutter_for_openharmony口腔护理app实战+知识实现
android·javascript·flutter
晚霞的不甘6 小时前
Flutter for OpenHarmony从基础到专业:深度解析新版番茄钟的倒计时优化
android·flutter·ui·正则表达式·前端框架·鸿蒙
鸟儿不吃草6 小时前
android的Retrofit请求https://192.168.43.73:8080/报错:Handshake failed
android·retrofit
Minilinux20186 小时前
Android音频系列(09)-AudioPolicyManager代码解析
android·音视频·apm·audiopolicy·音频策略
李子红了时7 小时前
【无标题】
android