app:mergeExtDexDebug,Program type already present:BuildConfig 的另类解决办法

博主遇到在集成aar包时出现'Program type already present: BuildConfig'的错误。尝试修改AndroidManifest.xml的package属性来解决,但发现需要大量代码调整。最终通过注释掉使用BuildConfig的代码解决了问题,不过此方法仅适用于BuildConfig不影响主要功能的情况。
摘要由CSDN通过智能技术生成

偶遇“路障”

  • 日前,加了个功能,引用了一个aar,在部署的时候,androidstudio报错了:
app:mergeExtDexDebug, Program type already present: BuildConfig

速清摸索

  • 看了看,是一个日期插件里使用 BuildConfig ,而我的代码里,使用 BuildConfig,
    从网上查了一些办法,能管用的一个办法是:修改项目清单文件AndroidManifest.xml里的package:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.test.cyun">

比如,修改为:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.test.cyun2">

辗转反侧

  • 但是这个办法的弊端就是:需要接着修改大量的代码引用,修改,检查,编译,修改…比较麻烦。
  • 所以我用一个helloworld的项目测试成功后,并没有在生产项目里进行这个修复工作,这个懒惰的程序员,开始想其他办法。

柳暗花明又一村

  • 百度了半天,无果,开始review,突然,灵光一现:
    • 我想起很久以前写代码,没使用过BuildConfig,也从来没有过这个异常信息。我理解为 BuildConfig 是使用后才生成的,不使用则不会生成,于是:
      把代码里与BuildConfig相关的代码,都注释掉了,
      比如:
        // 测试插件的TestActivity,点击登录页的logo进入插件测试页面,
//        if (BuildConfig.DEBUG) {
//            findViewById(R.id.iv_login_logo).setOnClickListener(new View.OnClickListener() {
//                @Override
//                public void onClick(View v) {
//                    Intent it = new Intent(context, TestActivity.class);
//                    startActivity(it);
//                }
//            });
//        }

重新编译,部署成功,问题解决。

露怯备注

  • 这个讨巧且并不严格的解决办法,只适用于:BuildConfig 只是用来便于在调试模式编译、操作,并不会影响程序主功能。
  • 如果确实需要使用主Module的BuildConfig,也许需要换个全局的静态变量去控制了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值