程序猿日常
快过年前踩坑!
Android 编译apk成功后 安装在不同的型号手机上,华为 小米 等6.0以上手机可以安装成功且可以正常使用,然而在 vivo 手机android 7.0 启动应用竟然崩溃,报错信息如下:
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.daniulive.smartpublisher/com.daniulive.smartpublisher.CameraPublishActivity}:
java.lang.ClassNotFoundException: Didn't find class "com.daniulive.smartpublisher.CameraPublishActivity" on path:
DexPathList[[zip file "/data/app/com.daniulive.smartpublisher-1/base.apk"]
,nativeLibraryDirectories=[/data/app/com.daniulive.smartpublisher-1/lib/arm64, /system/fake-libs64, /data/app/com.daniulive.smartpublisher-1/base.apk!/lib/arm64-v8a, /system/lib64, /vendor/lib64]]
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2727)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2886)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1623)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:186)
at android.app.ActivityThread.main(ActivityThread.java:6491)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:914)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:804)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.daniulive.smartpublisher.CameraPublishActivity" on path: DexPathList[[zip file "/data/app/com.daniulive.smartpublisher-1/base.apk"],nativeLibraryDirectories=[/data/app/com.daniulive.smartpublisher-1/lib/arm64, /system/fake-libs64, /data/app/com.daniulive.smartpublisher-1/base.apk!/lib/arm64-v8a, /system/lib64, /vendor/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at android.app.Instrumentation.newActivity(Instrumentation.java:1079)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2717)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2886)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1623)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:186)
at android.app.ActivityThread.main(ActivityThread.java:6491)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:914)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:804)
一看错误,第一反应是两种原因 一是 AndroidManifest.xml 中没有注册Activity(怎么可能犯这种低级错误呢?),二是 项目中使用的so文件不支持该机型;
难道vivo这款手机不是arm机型?使用的so包是支持所有arm机型的;进过查资料核实这款手机确实是arm 64位机,那到底是什么原因 = =;
坚持 不放弃,不抛弃 的开发精神,努力寻找原因,终于被我找到了;
项目中使用的gradle编译版本有关(不太明白)
将 classpath ‘com.android.tools.build:gradle:2.3.3’
改为 classpath ‘com.android.tools.build:gradle:2.2.0’
就可以了
在此记录下,有知道详细原因的请留言相告==