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);
    }


根据这个解决了问题。

  • 2018-04-15 12:56:05

    WebView控件之WebSettings各种配置方法源码总结

    WebSettings用于管理WebView状态配置,当WebView第一次被创建时,WebView包含着一个默认的配置,这些默认的配置将通过get方法返回,通过WebView中的getSettings方法获得一个WebSettings对象,如果一个WebView被销毁,在WebSettings中所有回调方法将抛出IllegalStateException异常。

  • 2018-04-16 07:28:10

    android点击事件,第一次无效,第二次才响应的问题

    今天碰到的问题,android的标题栏一个回退button,每次进入的时候第一次点击无效,一直到第二次点击时才响应,然后把代码copy到系统的回退按钮里面,结果每次都能响应,后面想了想,应该跟焦点有关系

  • 2018-04-18 15:56:00

    linux下如何实现mysql数据库每天自动备份定时备份

    备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程。而对于一些网站、系统来说,数据库就是一切,所以做好数据库的备份是至关重要的!

  • 2018-04-18 20:44:19

    $(...).live is not a function

    jquery中的live()方法在jquery1.9及以上的版本中已被废弃了,如果使用,会抛出TypeError: $(...).live is not a function错误。

  • 2018-04-19 16:31:03

    mysql双机热备的实现

    准备两个mysql,A和B,A为主,B为从。前提是这两个数据库现在的表结构要一模一样,否则不成功。这个要锁表处理了。

  • 2018-04-19 16:32:47

    mysql binlog_do_db参数设置的坑

    在配置文件中想当然地配置成binlog_do_db=test,xx,jj,以为是三个库。结果无论什么操作都没有binlog产生

  • 2018-04-20 02:11:58

    Android中finish掉其它的Activity

    在Android开发时,一般情况下我们如果需要关掉当前Activity非常容易,只需要一行代码 this.finish;即可。 那么,如果是想要在当前Activity中关掉其它的Activity应该怎么实现呢? 比如更改了某个设定,程序需要重新运行并加载新的配置文件,就要用到restart或finish让程序重启。