博客
关于我
Android google Multidex分包 gradle 3.1.0 坑
阅读量:512 次
发布时间:2019-03-07

本文共 977 字,大约阅读时间需要 3 分钟。

在配置Android项目的multidex时,我们可能会遇到每个dex文件的方法数超出限制的问题。让我分享一下在不同版本gradle下的解决方案以及优化方法。

  • 问题背景为了优化应用性能,采用multidex将类和方法分散到多个dex文件中。但在百度加固过程中,每个dex文件的方法数限制为65530。之前版本的应用在某个dex中突破了这个限制,导致加固失败。

  • 初步解决方案通过查找资料,发现两种可能的解决方案:

    • 使用gradle选项--set-max-idx-number=48000。在Q一下版本中配置additionalParameters,逐一添加参数。
    • third-party工具dexknife,但未成功故选择第一种方法。
    1. 遇到的配置问题build.gradle中添加了additionalParameters,尝试设置--set-max-idx-number=48000。然而在较新版本的gradle(3.1.0及以上)中,这种设置不起作用。

    2. 版本对编译工具的影响了解到从gradle 3.1.0开始,宏类开始使用D8编译工具。D8的编译方式可能与旧版本不同,原有的分包配置方法在新版本下不可行。在低版本gradle(3.0.0及以下)中,分包和加固可行,但性能可能较低。

    3. 找到正确配置方法进一步研究发现,需要在build.gradle中使用dexOptions块,添加additionalParameters,指定--set-max-idx-number=value,这样可以在版本较低的gradle中实现。在较高版本gradle中,如果必须保留D8工具,则需要禁用D8编译选项android.enableD8=false,然后使用模拟器或特定编译规则。

    4. 实验与验证降低gradle到3.0.0,成功分包,方法数控制在48000以下。在较高版本gradle中,尝试两个选项:

      • 配置dexOptions,添加所需参数。
      • 禁用D8,使用rostoolchain,进行临时测试。
      1. 总结与建议目前,使用dexOptions配置正确可以解决问题。对于较高版本gradle,需 额外设置启用旧工具或者调整开发环境,如NDK。同时,测试不同配置下的性能差异,选择最优解。
      2. 通过以上步骤,成功实现了每个dex文件的方法数限制,可以使百度加固过程顺利进行。

    转载地址:http://giejz.baihongyu.com/

    你可能感兴趣的文章
    Objenesis创建类的实例
    查看>>
    ObsoleteAttribute 可适用于除程序集、模块、参数或返回值以外的所有程序元素。 将元素标记为过时可以通知用户:该元素在产品的未来版本中将被移除。...
    查看>>
    OC Xcode快捷键
    查看>>
    OC 内存管理黄金法则
    查看>>
    OfficeWeb365 SaveDraw 文件上传漏洞复现
    查看>>
    office中的所有content type
    查看>>
    office之Excel 你会用 Ctrl + E 吗?
    查看>>
    OGG初始化之使用数据库实用程序加载数据
    查看>>
    ogg参数解析
    查看>>
    ognl详解
    查看>>
    Oil Deposits
    查看>>
    OJ中处理超大数据的方法
    查看>>
    OJ中常见的一种presentation error解决方法
    查看>>
    OK335xS UART device registe hacking
    查看>>
    ok6410内存初始化
    查看>>
    Okhttp3添加拦截器后,报错,java.io.IOException: unexpected end of stream on okhttp3.Address
    查看>>
    OKR为什么到今天才突然火了?
    查看>>
    ol3 Demo2 ----地图搜索功能
    查看>>
    OLAP在大数据时代的挑战
    查看>>
    oldboy.16课
    查看>>