flutter:构建失败的原因总结

记一次Flutter 构建失败原因总结

根据之前的构建过程,我总结了以下几个主要问题:


最近使用trae来接管我的前端开发,并且将代码任务从react和compose转向了flutter。但是flutter没有更多的开发和构建经验,所以在鼓捣配置的过程中耗费了大量的时间,尽管有trae cn的帮助。现在分享出来,希望能帮到更多的人。

1. Gradle 与 AGP 版本不兼容

错误信息:

复制代码
Could not create an instance of type com.android.build.api.variant.impl.LibraryVariantBuilderImpl

原因: Gradle 8.14 与 Android Gradle Plugin (AGP) 8.1.0 版本不兼容

解决方案: 升级 AGP 到 8.4.0+ 以兼容 Gradle 8.14

kotlin 复制代码
// android/build.gradle.kts
dependencies {
    classpath("com.android.tools.build:gradle:8.4.0")  // 从 8.1.0 升级
    classpath("org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.20")
}

2. Gradle 缓存损坏

错误信息:

复制代码
Could not deserialize analysis from a file: ...instrumentation-hierarchy.bin
UncheckedExecutionException: java.lang.IllegalStateException

原因: Gradle 缓存文件损坏或不完整

解决方案:

bash 复制代码
flutter clean
# 或手动删除 C:\Users\HP\.gradle\caches\8.14

3. 磁盘空间不足

错误信息:

复制代码
java.io.IOException: 磁盘空间不足

原因: C 盘可用空间不足,Gradle 需要大量临时存储

解决方案: 将 Gradle 缓存目录指向空间充足的分区:

properties 复制代码
# android/gradle.properties
GRADLE_USER_HOME=D:\code\.gradle

4. Maven 仓库 URL 语法错误

问题: Kotlin DSL 中 maven { url '...' } 语法不正确

错误代码:

kotlin 复制代码
maven { url 'http://maven.aliyun.com/...' }  // ❌ 错误

正确代码:

kotlin 复制代码
maven { url = uri("https://maven.aliyun.com/...") }  // ✅ 正确

5. AndroidX 配置缺失

警告信息:

复制代码
Your app isn't using AndroidX

解决方案:gradle.properties 中启用 AndroidX:

properties 复制代码
android.useAndroidX=true
android.enableJetifier=true

6. Gradle 版本被意外更改

问题: 配置文件中的 Gradle 版本被改成了 8.5,而用户需要使用 8.14

解决方案: 保持用户指定的配置:

properties 复制代码
# gradle-wrapper.properties
distributionUrl=file:///D:/code/gradle-8.14-all.zip

7. 依赖版本冲突

问题: pubspec.yaml 中某些依赖版本过低或不兼容

解决方案: 使用稳定且兼容的依赖版本:

yaml 复制代码
dependencies:
  dio: ^5.4.3+1
  video_player: ^2.8.6
  shared_preferences: ^2.2.2
  go_router: ^12.1.3

最终成功构建的关键配置

配置项
Gradle 8.14 (本地)
AGP 8.11.1
Kotlin 2.2.20
compileSdk 31
minSdk flutter.minSdkVersion
AndroidX ✅ 已启用
Maven 镜像 阿里云 (https)

建议

  1. 保持网络畅通 - 首次构建需要下载大量依赖
  2. 定期清理缓存 - 使用 flutter clean 避免缓存问题
  3. 使用国内镜像 - 加速依赖下载
  4. 保持配置稳定 - 不要随意更改 Gradle 和 AGP 版本
相关推荐
私人珍藏库1 分钟前
【Android】iTubeGo(去除限制)
android·智能手机·app·工具·多功能
2601_954706499 分钟前
云手机虚拟化技术深度拆解:从安卓容器到 GPU 直通
android·智能手机
范特西林15 分钟前
Android 16 AppFunction 机制分析
android·ai编程
风华圆舞20 分钟前
鸿蒙防窥保护 的 Flutter 侧封装思路
flutter·华为·harmonyos
Coffeeee24 分钟前
Android16升级,预测性返回适配起来到底难不难
android·程序员·kotlin
_李小白27 分钟前
【android opencv学习笔记】Day 33: 直线检测之图像轮廓检测
android·opencv·学习
Mars-xq31 分钟前
vscode 开发Android
android·ide·vscode
__Witheart__37 分钟前
关于 uname 查看的内核版本号的后缀
android·linux·ubuntu·rockchip
风华圆舞42 分钟前
SpeechRecognitionChannel 的 Flutter 侧封装思路
flutter·华为·harmonyos
QING6181 小时前
Kotlin 协程新手指南 —— 结构化并发
android·kotlin·android jetpack