错误如图:
上图是在github replugin issues 中找的图,但是报错跟我基本一致。使用application 获取本地资源失败。但是神奇的是调用Replugin.getPluginContext()可以运行正常(但是太多地方需要替换context)。这明显是不正常的,因为我是在自己插件中调用自己插件的资源,打印出来的context对象都是自己内部的,参照文档外置插件和单独APK一样不需要做特殊修改。
对于上面的问题我做了以下设想和验证。
1.官方demo1 测试是否存在application 获取本地资源失败情况
验证结果 不存在可以正常使用
2.验证是否和androidx 有关。
把demo1升级成androidx ,验证结果可以正常使用
3.验证是否和我们项目的build.gradle配置有关。
把我们项目中的所有配置在demo1中配置一边,验证结果可以正常使用。
4.验证是否跟多dex打包有关。
把demo1方法数超过65535 开启多dex打包,验证结果可以正常使用。
好吧,我已经莫得感情了。
后来查找代码,发现在application中有初始化国际化相关代码,会重新设置resources。
private static Context updateResources(Context context, Locale locale) {
if (locale == null) {
return context;
}
Locale.setDefault(locale);
Resources res = context.getResources();
Configuration config = new Configuration(res.getConfiguration());
if (Build.VERSION.SDK_INT >= 17) {
config.setLocale(locale);
context = context.createConfigurationContext(config);
} else {
config.locale = locale;
res.updateConfiguration(config, res.getDisplayMetrics());
}
return context;
}
果然这里去掉以后问题就解决了。
同样的bug 但是每个人出现问题的原因可能不一样。归根结底还是context问题,查找哪些地方更改了context,去试试吧