Pra*_*war 1 java android android-gradle-plugin android-multidex android-studio-2.1
所以我现在面对这个问题一段时间了.调试时我正在使用运行Android 5.1(L)的设备.当我完成后,我app-debug.apk从中获取/app/build/output/apk并通过Beta(由Fabric)将其转发给测试部门.
所以在测试人员方面,当安装在运行Android 4.4(K)的设备上时,应用程序在打开时会崩溃.这不是Fabric的问题,因为其他渠道如松弛,电子邮件等也会发生同样的事情.
如果我在运行Android K的模拟器上再次构建应用程序并发送apk,它将在测试设备上正常运行.是的,应用程序在运行Android 4.4的多个设备上崩溃了.
我在SO上找不到与此有关的内容,所以想想把它放好.这是Android Studio的已知问题还是我错过了什么?
我正在使用:
如果这不是一个错误,这是否意味着我们必须在较低的Android版本上生成签名的apk,以便它可以在所有设备上运行?
有谁知道这个问题?
更新: Android K上崩溃的版本在Android L及更高版本上运行正常.
更新:我能够获得Logcat:
FATAL EXCEPTION: mainProcess: com.myapp.qa, PID: 3570 java.lang.RuntimeException: Unable to instantiate application com.android.tools.fd.runtime.BootstrapApplication: java.lang.ClassNotFoundException: Didn't find class "com.android.tools.fd.runtime.BootstrapApplication" on path: DexPathList[[zip file "/data/app/com.myapp.qa-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.myapp.qa-2, /vendor/lib, /system/lib]]
at android.app.LoadedApk.makeApplication(LoadedApk.java:516)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4317)
at android.app.ActivityThread.access$1500(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
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:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.android.tools.fd.runtime.BootstrapApplication" on path: DexPathList[[zip file "/data/app/com.myapp.qa-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.myapp.qa-2, /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.Instrumentation.newApplication(Instrumentation.java:975)
at android.app.LoadedApk.makeApplication(LoadedApk.java:511)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4317)
at android.app.ActivityThread.access$1500(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
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:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)
更新2016年7月12日:我已经尝试添加多dex支持,但它没有解决问题.logcat提供相同的日志.
请检查您是否启用了即时运行选项.
转到Android Studio的"首选项",然后在" 构建,执行,部署"下找到" 即时运行"选项.
取消选中复选框以禁用即时运行,然后再次清除并在您的设备中构建代码.然后将调试apk传递给测试团队.希望这次不会崩溃.
更新
好像你的问题已经在这里被问到并回答了.尝试启用multidex支持build.gradle.
defaultConfig {
...
minSdkVersion 14
targetSdkVersion 21
...
// Enabling multidex support.
multiDexEnabled true
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1499 次 |
| 最近记录: |