博客
关于我
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/

    你可能感兴趣的文章
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>