接手的项目中,之前负责的同事用了ActiveAndroid的数据库开源框架,原本在android4.2和android5.0的系统上用得好好的。可是最近要求更换中间件,而中间件中依赖了httpcore和httpmime,结果就导致了ActiveAndroid闪退了。
java.lang.IncompatibleClassChangeError: org.apache.http.params.SyncBasicHttpParams
at dalvik.system.DexFile.defineClassNative(Native Method)
at dalvik.system.DexFile.defineClass(DexFile.java:226)
at dalvik.system.DexFile.loadClassBinaryName(DexFile.java:219)
at dalvik.system.DexPathList.findClass(DexPathList.java:321)
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:54)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:308)
at com.activeandroid.ModelInfo.scanForModelClasses(ModelInfo.java:187)
at com.activeandroid.ModelInfo.scanForModel(ModelInfo.java:152)
at com.activeandroid.ModelInfo.<init>(ModelInfo.java:63)
at com.activeandroid.Cache.initialize(Cache.java:66)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:44)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:34)
at com.activeandroid.ActiveAndroid.initialize(ActiveAndroid.java:30)
at com.eebbk.syncpointread.base.EnglishReadApplication$14.run(EnglishReadApplication.java:254)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
在GitHub上查看了ActiveAndroid的源码,确实是不依赖其他,然而为什么会报这个问题呢?
IncompatibleClassChangeError 从字面理解应该不兼容的类改变引起的错误,因为是更换中间件从而增加了httpcore和httpmime的依赖,所以可以确定是这两个重复了。但是因为是中间件依赖的,不能单纯的去掉,那么是否可以从其他方面规避这个问题,从而使ActiveAndroid正常初始化呢?
通过查看ActiveAndroid 的源码可以知道,ActiveAndroid 有三种初始化方式:
public static void initialize(Context context) {
initialize((new Builder(context)).create());
}
public static void initialize(Configuration configuration) {
initialize(configuration, false);
}
public static void initialize(Context context, boolean loggingEnabled) {
initialize((new Builder(context)).create(), loggingEnabled);
}
public static void initialize(Configuration configuration, boolean loggingEnabled) {
setLoggingEnabled(loggingEnabled);
Cache.initialize(configuration);
}
原来是通过
ActiveAndroid.initialize(context);
初始化ActiveAndroid。
换成用以下方式初始化:
Configuration.Builder configurationBuilder = new Configuration.Builder(context);
configurationBuilder.addModelClass(Address.class);
configurationBuilder.addModelClass(HardWord.class);
ActiveAndroid.initialize(configurationBuilder.create());
** 编译,运行,顺利搞定! **