添加contentProvider,运行时出现:unable to get provider com.***.***.provider:java.lang.ClassNotFoundException:Didn't find class "com.android.providers.***provider" on path:DexPathList [[zip file "/system/app/"]]
解决思路:
1、class not found ,首先应该考虑的是,AndroidManifest.xml配置是否正确,provdier的name,authority,Android.mk文件是否生成对应的provider 模块。
2、如排除一的可能性,可在ActivityThread.java中添加响应的log,即在操作provider,插入数据时,ActivityThread会去加载provider实例,此时,根据添加的log,可以定位,在实例的哪一步发生了问题,我是在localProvider = (ContentProvider)cl.loadClass (info.name).newInstance()时出现异常。可以断定,是虚拟机的加载出了问题。
3、使用工具,打开源码编译生成的***provider.odex,***provider.vdex,发现这两个文件均为空,因此判断编译apk出问题,将写的provider放到同事源码环境下编译,生成apk有效。
4、因此,我的问题是,编译时,未能有效加载class,可能时out目录下有残余无效模块。 我为provider添加了res目录,定义了一些String,并在ANdroidManifest.xml中引用,问题解决。