美文网首页
Gradle3.2.x分包填坑

Gradle3.2.x分包填坑

作者: Parallel_Lines | 来源:发表于2018-11-01 16:12 被阅读0次

    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分包填坑

          本文链接:https://www.haomeiwen.com/subject/giuxxqtx.html