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-10-27 17:24:45

    使用localstorage和预加载做到webview秒开

    提到网页加载速度优化,大家都会想到静态资源上CDN,CSS和JS文件合并,图片合并成雪碧图等常用手段;但是在某些特殊情况下这些常用方法也无法达到理想的效果。比如,在国际化场景下,很多国家还停留在2G网络阶段,无论如何优化,都无法避免过慢的网络请求。最近一直在做国际化(主要是印尼和泰国)背景下的webview性能优化,也算有一些经验。由于我们的产品是面向android用户的,而android手机对H5支持很好,因此我们主要是应用H5的新特性。

  • 2018-10-28 10:50:26

    VectorDrawable简单介绍

    在项目中使用矢量图至少可以缩小我们apk包的尺寸,而且可以在屏幕适配时提供很大的方便,因为矢量图是分辨率无关的。

  • 2018-10-28 11:14:29

    矢量资源工具Vector_Asset_Studio

    Android Studio有一个称为“Vector Asset Studio”的工具, 它可以将SVG文件和PSD文件转化为工程可用的矢量可绘制资源(vector drawable resources),

  • 2018-10-28 11:16:09

    Android vector标签 PathData 画图超详解

    SVG是一种矢量图格式,是Scalable Vector Graphics三个单词的首字母缩写。在xml文件中的标签是<vector>,画出的图形可以像一般的图片资源使用,例子如下

  • 2018-10-30 00:16:41

    android ToolBar 设置颜色

    app:popupTheme——有时候我们有需求:ActionBar文字是白的,ActionBar Overflow弹出的是白底黑字让ActionBar文字是白的,那么对应的theme肯定是Dark。可是让ActionBar弹出的是白底黑字,那么需要Light主题。这时候popupTheme就派上用场了。android:theme 与app:theme——在AppCompat v21里,提供了一个快速方便的方法设置Toolbar的主题,使用app:theme。而新版本22.1.x中,AppCompat 允许对 Toolbar 使用 android:theme代替 app:theme。最好的一点是:它会自动继承父视图的theme ,并且兼容所有APIv11以上的设备。