8

我看到带有 Android 4.4.2 的三星 Galaxy S5 崩溃

NoClassDefFoundError: android/view/ViewStructure

自从我将支持库更新到 26.0.2 以来,这种情况一直在发生。现在它也发生在 27.0.0 上,尽管我预计这些问题已经在其中得到解决。在将应用程序提交到 Google Play 后不久,我在 Crashlytics 中看到了一次崩溃(我正在向一小部分用户推出)。我不知道重现的确切步骤是什么。到目前为止,我认为这可能是应用程序启动的时候。

相关报道:

java.lang.NoClassDefFoundError: android/graphics/drawable/Icon

ViewDebug.getExportedPropertyMethods java.lang.NoClassDefFound android/graphics/drawable/Icon

我正在使用支持库 27.0.0、compileSdkVersion 27、targetSdkVersion 25、buildToolsVersion '26.0.2'、android 插件 2.3.3、gradle 3.3、Android Studio 3.0。(我猜这个问题与旧版本的 gradle 和插件无关?...)

我可以看到 ViewStructure 在支持库中使用:

android.support.design.widget.TextInputLayout 
android.support.design.testutils.ViewStructureImpl

但是,我没有在项目中的任何地方使用 ViewStructure。

Fatal Exception: java.lang.NoClassDefFoundError: android/view/ViewStructure
       at java.lang.Class.getDeclaredMethods(Class.java)
       at java.lang.Class.getDeclaredMethods(Class.java:656)
       at android.view.ViewDebug.getExportedPropertyMethods(ViewDebug.java:960)
       at android.view.ViewDebug.exportMethods(ViewDebug.java:1047)
       at android.view.ViewDebug.dumpViewProperties(ViewDebug.java:997)
       at android.view.ViewDebug.dumpViewProperties(ViewDebug.java:983)
       at android.view.ViewDebug.dumpView(ViewDebug.java:900)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:855)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dump(ViewDebug.java:793)
       at android.view.ViewDebug.dispatchCommand(ViewDebug.java:416)
       at android.view.ViewRootImpl$W.executeCommand(ViewRootImpl.java:6258)
       at android.view.IWindow$Stub.onTransact(IWindow.java:65)
       at android.os.Binder.execTransact(Binder.java:404)
       at dalvik.system.NativeStart.run(NativeStart.java)
Caused by java.lang.ClassNotFoundException: Didn't find class "android.view.ViewStructure" on path: DexPathList[[zip file "/data/app/package.name-1.apk"],nativeLibraryDirectories=[/data/app-lib/package.name-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 java.lang.Class.getDeclaredMethods(Class.java)
       at java.lang.Class.getDeclaredMethods(Class.java:656)
       at android.view.ViewDebug.getExportedPropertyMethods(ViewDebug.java:960)
       at android.view.ViewDebug.exportMethods(ViewDebug.java:1047)
       at android.view.ViewDebug.dumpViewProperties(ViewDebug.java:997)
       at android.view.ViewDebug.dumpViewProperties(ViewDebug.java:983)
       at android.view.ViewDebug.dumpView(ViewDebug.java:900)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:855)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dumpViewHierarchy(ViewDebug.java:867)
       at android.view.ViewDebug.dump(ViewDebug.java:793)
       at android.view.ViewDebug.dispatchCommand(ViewDebug.java:416)
       at android.view.ViewRootImpl$W.executeCommand(ViewRootImpl.java:6258)
       at android.view.IWindow$Stub.onTransact(IWindow.java:65)
       at android.os.Binder.execTransact(Binder.java:404)
       at dalvik.system.NativeStart.run(NativeStart.java)
4

2 回答 2

5

此问题最可能的原因是用户不是普通用户,因为“只有在连接了 hierarchyviewer / ddm 时才会发生这种情况”。

更多信息可以在这里找到:

https://issuetracker.google.com/issues/68796830

于 2017-11-02T16:35:32.240 回答
0

我正在从 25.3.1 迁移到 Support lib 27.1.1(是的,这里的人们移动速度不快......)并且在给TextInputLayouts 充气时也面临同样的崩溃。

经过一番调查,事实证明我们有一个自定义LayoutInflater,它遍历完整的视图层次结构并injectMembers(View)在每个带有Guice的视图中注入依赖项(使用) (可能也会影响 dagger)。这是必需的,因为我们有自定义视图,它具有通过@Inject.

由于 Guice 遍历该类并在解析依赖项时尝试访问它的公共方法,因此它遇到了 egTextInputLayout.dispatchProvideAutofillStructure(ViewStructure, int)导致崩溃,因为ViewStructure在运行 < API 23 的设备上不可用。

所以这是一个关于什么导致我们问题的例子,我们还没有一个好的解决方案,但可能我们要么摆脱自定义视图中的注入,要么我们注释这些视图,以便在遍历视图树时只注入这些视图.

于 2018-05-09T11:39:09.850 回答