MultidexApplication相关的一个crash

最近在内测的一个App在内测开始后有用户反馈启动就crash的问题,后来拿到用户的信息后发现几个crash的机器都是4.4的机器,因为现在真实用户使用4.4系统的用户真的是不多了,就没怎么在意,但是在阿里云移动测试平台进行兼容性测试的时候,这个问题必现,并且都出现在4.4的机器上,查看兼容性测试报告,都是同一个crash,崩溃的堆栈记录了下来:

FATAL EXCEPTION: main Process: com.ross.android, PID: 9282 java.lang.RuntimeException: Unable to get provider com.readystatesoftware.chuck.internal.data.ChuckContentProvider: 
java.lang.ClassNotFoundException: Didn't find class "com.readystatesoftware.chuck.internal.data.ChuckContentProvider" on path: DexPathList[[zip file "/data/app/com.ross.android-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.ross.android-1, /vendor/lib, /system/lib]] 
at android.app.ActivityThread.installProvider(ActivityThread.java:5060) 
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4631) 
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4571) 
at android.app.ActivityThread.access$1500(ActivityThread.java:155) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1406) 
at android.os.Handler.dispatchMessage(Handler.java:110) 
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:5341) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:515) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:830) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:646) 
at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.ClassNotFoundException: Didn't find class "com.readystatesoftware.chuck.internal.data.ChuckContentProvider" on path: DexPathList[[zip file "/data/app/com.ross.android-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.ross.android-1, /vendor/lib, /system/lib]] at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:497) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
at android.app.ActivityThread.installProvider(ActivityThread.java:5045) 
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4631)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4571) 
at android.app.ActivityThread.access$1500(ActivityThread.java:155) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1406) 
at android.os.Handler.dispatchMessage(Handler.java:110) 
at android.os.Looper.loop(Looper.java:193) 
at android.app.ActivityThread.main(ActivityThread.java:5341) 
at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:830) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:646) 
at dalvik.system.NativeStart.main(Native Method)

看到这个崩溃的记录后,赶紧去查看到了build.gradle中multiDexEnabled选项,果然是true,处于打开状态,然后看了本App的Application竟然并没有继承自MultiDexApplication,在Application的onCreate的方法中也没有调用MultiDex.install(this), 这也就难怪在4.4中出现这个崩溃了,因为貌似这个崩溃只出现在 api<21 的情况下, 因为我平时的开发机都是8.0的系统,所以这个问题一直没有暴露出来, 直到将这个App安装在用户的机器上,崩溃出现了,这个问题解决起来其实很简单,要么将本App的Application继承自MultiDexApplication, 要么在Application中的onCreate中调用MultiDex.install(this)。就是这么简单,那这么简单的一个问题为什么要专写一篇来记录呢?其实也是因为这次这个内测阶段的crash的问题很典型,它就是在开发工程中被忽略,或者现有环境没有覆盖到,导致崩溃出现在了用户的机器上,其实这类问题是可以在发布版本前就能避免的,算是一次很好的教训。 解决方案再明确下:

  • 方法一
TestApplcation extends MultiDexApplication {


}


  • 方法二
TestApplcation extends Application {

    @Override
	public void onCreate() {
		super.onCreate();

        MultiDex.install(this);
    }

}