multidex 在api 19 遇到的问题,启动闪退,不报错

2018-02-17 18:20:27

今天用华为4.4系统的api19 ,用android Studio 直接运行app,结果闪退,没有一个错误信息,这就操蛋了,懵逼了。


但是我混淆打包以后的不会出现问题。

只有下面这个报错信息。

threadid=1: thread exiting with uncaught exception (group=0x40...)

百度搜错,说通过UncaughtExceptionHandler  这个接口可以获得报错信息。


结果依然没有出现报错信息。

最后也巧,手边还有一个破旧的小米4.4系统的,运行也是闪退,不过幸运的是这个出现了报错信息。


 java.lang.RuntimeException: Unable to get provider android.support.v4.content.FileProvider: java.lang.ClassNotFoundException: Didn't find class "android.support.v4.content.FileProvider" on path: DexPathList[[zip file "/data/app/com.zyjr.emergencylending-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.zyjr.emergencylending-1, /vendor/lib, /system/lib]]
                                                     at android.app.ActivityThread.installProvider(ActivityThread.java:4892)
                                                     at android.app.ActivityThread.installContentProviders(ActivityThread.java:4484)
                                                     at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4424)
                                                     at android.app.ActivityThread.access$1500(ActivityThread.java:143)
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1269)
                                                     at android.os.Handler.dispatchMessage(Handler.java:102)
                                                     at android.os.Looper.loop(Looper.java:136)
                                                     at android.app.ActivityThread.main(ActivityThread.java:5120)
                                                     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:818)
                                                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:634)
                                                     at dalvik.system.NativeStart.main(Native Method)
                                                  Caused by: java.lang.ClassNotFoundException: Didn't find class "android.support.v4.content.FileProvider" on path: DexPathList[[zip file "/data/app/com.zyjr.emergencylending-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.zyjr.emergencylending-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:4877)
                                                     at android.app.ActivityThread.installContentProviders(ActivityThread.java:4484) 
                                                     at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4424) 
                                                     at android.app.ActivityThread.access$1500(ActivityThread.java:143) 
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1269) 
                                                     at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                     at android.os.Looper.loop(Looper.java:136) 
                                                     at android.app.ActivityThread.main(ActivityThread.java:5120) 
                                                     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:818) 
                                                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:634) 
                                                     at dalvik.system.NativeStart.main(Native Method) 


在网上找了好多资料,找了好久,终于解决了,希望能帮到需要的人,也帮自己记录一下!

解决方法:
可能是添加MultiDex分包,但未初始化的原因,在Application中重写attachBaseContext函数,对MultiDex初始化即可。
1)首先修改Gradle配置文件,启用MultiDex并包含MultiDex支持:

	defaultConfig {       		 multiDexEnabled true 		}

2)修改BaseApplication,重写attachBaseContext方法


 @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        MultiDex.install(base);
    }


根据这个解决了问题。

  • 2020-03-06 22:28:05

    git中submodule子模块的添加、使用和删除

    执行成功后,git status会看到项目中修改了.gitmodules,并增加了一个新文件(为刚刚添加的路径) git diff --cached查看修改内容可以看到增加了子模块,并且新文件下为子模块的提交hash摘要 git commit提交即完成子模块的添加

  • 2020-03-09 21:34:48

    Android TV 包安装成功后找不到启动图标

    生成APK文件,用U盘插入到小米盒子上,然后点击安装,提示安装成功。 可是找不到启动图标,安装成功的弹窗也没有打开的选项。 而我之前测试装的一款手机应用是可以找到启动图标的。

  • 2020-03-09 21:37:10

    安卓Tv端App开发与手机端的开发的区别

    因为大部分电视机的配置一般都比手机低,但是电视机一般都是用来看视频的,所以在做视频解码的时候,因为电视机配置比较低,所以大多数手机运行流畅的播放器在电视机上面都会卡顿,或者出现一些其他的问题,经过我同事长时间的测试,认为百度播放器跟小米播放器比较适合电视机作为播放器开发使用。如果你们要选择一个播放器,要先拿一个demo去很多台不同类型的电视机去测试,因为网络上面的播放器在电视机卡的真的很多,先测试好了再使用可以节约大家的时间。

  • 2020-03-09 22:11:39

    聊聊真实的 Android TV 开发技术栈

    智能电视越来越普及了,华为说四月发布智能电视跳票了,一加也说今后要布局智能电视,在智能电视方向,小米已经算是先驱了。但是还有不少开发把智能电视简单的理解成手机屏幕的放大,其实这两者并不一样。

  • 2020-03-11 09:43:20

    JavaScript shift() 方法

    shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。