关于Android版本适配过程中,包体积增大问题排查

包体积增大问题

核心调整:

android:extractNativeLibs=“true”

默认值取值:
首先,android:extractNativeLibs 属性的默认值取决于几个因素:

  • minSdkVersion:即应用支持的最低 API 级别。
  • AGP (Android Gradle Plugin) 版本:即构建应用时使用的 Gradle 插件版本。

生效限制:
这个属性在 minSdkVersion >= 23 和 Android Gradle Plugin >= 3.6.0 的情况下生效。

作用:

  • 这个属性决定了应用是否应该解压原生库文件(.so 文件)到设备的文件系统。(true=解压)
  • 如果 .so 文件不被解压,它们会直接包含在 APK 中,这可能会导致 APK 的大小增加。
  • 加载性能提高,不需要在应用启动时解压 .so 文件,因此应用的启动速度可能会有所提高。

关于AGP的分界线是3.6.0还是4.2.0的分析

  • 如果你使用的是 AGP 3.6.0 至 AGP 4.1.x 的版本,那么只有当 minSdkVersion >= 23 时,android:extractNativeLibs 的默认值才是 false。
  • 如果你使用的是 AGP 4.2.0 或更高版本,无论 minSdkVersion 的值是多少,android:extractNativeLibs 的默认值都是 false。
  • 因此,AGP 4.2.0 是一个更为严格的分界线,它改变了所有应用的默认行为,而 AGP 3.6.0 则是针对特定 minSdkVersion 的分界线。如果你的应用使用的是 AGP 4.2.0 或更高版本,那么默认情况下 .so 文件不会被解压到文件系统中。

原因分析:
本次适配工作中,将minSdkVersion 从21升级到24版本。 而apg为4.2.0没做调整。
因此,在apg4.2.0版本并且minSdkVersion = 21的旧版本中,默认android:extractNativeLibs=“true”。
而本次因为升级了minSdkVersion ,受minSdkVersion 影响,默认android:extractNativeLibs=“false”。

解决方案:
目前通过在清单文件中,显式设置android:extractNativeLibs="true"的方式,apk体积有了明显下降,从388M降到246M。