Gradle3.2.x分包填坑

Gradle从2.x升级至3.2.x以后,遇到很多问题,这里做下记录。

这是原先的分包方式:

app build.gradle文件

multiDexEnabled = true
multiDexKeepProguard file('multiDexKeep.txt')

dexOptions {
    javaMaxHeapSize "4g"
    keepRuntimeAnnotatedClasses false
    additionalParameters += '--set-max-idx-number=62000'
    jumboMode = true
}

由于公司项目使用了梆梆加固,梆梆对每一个dex文件都有最大方法数和最大字符数的要求,总之就是:加固后的dex文件方法数和字符数均不能超过65535,所以梆梆自己定义了一个加固前的“合适”方法数:62000。

升级Gradle3.2.x以后,加固时发现因方法超限而失败了,检查后发现:
分包确实成功了,但是方法数没有按照要求限制在62000以内。

之后通过多方查找,通过在gradle.properties文件加入以下俩个属性 ①解决了不按照方法数限制分包的问题。

android.enableD8=false
//虽然useDexArchive提示过期,但是该属性必须有
android.useDexArchive=false

这次打包加固方法数终于不超限了,然而字符数超限了...(一万只草泥马...)

字符数没有显式的属性可以控制,但是可以想到字符数是和方法数有直接关联的,方法数减少字符数自然就能减少了。

经过测试,梆梆提供的62000只能满足方法数的要求,字符数在很大概率上还是会超限的。当方法数<58000~60000 ②时,基本就能满足梆梆的要求了。

于是我按下面方式去配置build.gradle:

    dexOptions {
        javaMaxHeapSize "4g"
        keepRuntimeAnnotatedClasses false
        additionalParameters += '--multi-dex'
        additionalParameters += '--set-max-idx-number=59000'
        additionalParameters += '--minimal-main-dex'
        jumboMode = true
    }

这时报错说main dex方法数超限了,原来是multiDexKeepProguard file('multiDexKeep.txt')中配置了太多的class在主dex中,这时候就需要根据项目酌情删减 ③了。

从主dex中移除了非必须的class后,终于满足了方法数小于59000的要求,这时加固后的方法数和字符数均小于65535,加固成功。

你可能感兴趣的:(Gradle3.2.x分包填坑)