【问题标题】:Custom AOSP Keyboard Error: DictionaryProvider ClassNotFoundException自定义 AOSP 键盘错误:DictionaryProvider ClassNotFoundException
【发布时间】:2015-01-21 06:39:12
【问题描述】:

在添加一些自定义代码以获取按键触摸的压力值后,我正在尝试从 5.0.2 分支构建 AOSP 键盘。添加更改后,我使用 lunch full-eng 构建源代码并使用 mm 构建 LatinIME。

在删除之前的版本后,我会将 LatinIME 推送到我的 Galaxy S3 上的 /system/apps/。我正在设备上运行非官方版本的 CM12 5.0.2。

我得到的错误如下,这似乎与我的代码更改无关,但更可能与我构建应用程序的方式有关。

E/AndroidRuntime(12198): FATAL EXCEPTION: main
E/AndroidRuntime(12198): Process: com.android.inputmethod.latin, PID: 12198
E/AndroidRuntime(12198): java.lang.RuntimeException: Unable to get provider com.android.inputmethod.dictionarypack.DictionaryProvider: java.lang.ClassNotFoundException: Didn't find class "com.android.inputmethod.dictionarypack.DictionaryProvider" on path: DexPathList[[zip file "/system/app/LatinIME.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
E/AndroidRuntime(12198):    at android.app.ActivityThread.installProvider(ActivityThread.java:4969)
E/AndroidRuntime(12198):    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4561)
E/AndroidRuntime(12198):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4501)
E/AndroidRuntime(12198):    at android.app.ActivityThread.access$1500(ActivityThread.java:144)
E/AndroidRuntime(12198):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1339)
E/AndroidRuntime(12198):    at android.os.Handler.dispatchMessage(Handler.java:102)
E/AndroidRuntime(12198):    at android.os.Looper.loop(Looper.java:135)
E/AndroidRuntime(12198):    at android.app.ActivityThread.main(ActivityThread.java:5223)
E/AndroidRuntime(12198):    at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime(12198):    at java.lang.reflect.Method.invoke(Method.java:372)
E/AndroidRuntime(12198):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:898)
E/AndroidRuntime(12198):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693)
E/AndroidRuntime(12198): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.android.inputmethod.dictionarypack.DictionaryProvider" on path: DexPathList[[zip file "/system/app/LatinIME.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
E/AndroidRuntime(12198):    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
E/AndroidRuntime(12198):    at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
E/AndroidRuntime(12198):    at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
E/AndroidRuntime(12198):    at android.app.ActivityThread.installProvider(ActivityThread.java:4954)
E/AndroidRuntime(12198):    ... 11 more
E/AndroidRuntime(12198):    Suppressed: java.lang.ClassNotFoundException: com.android.inputmethod.dictionarypack.DictionaryProvider
E/AndroidRuntime(12198):        at java.lang.Class.classForName(Native Method)
E/AndroidRuntime(12198):        at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
E/AndroidRuntime(12198):        at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
E/AndroidRuntime(12198):        at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
E/AndroidRuntime(12198):        ... 13 more
E/AndroidRuntime(12198):    Caused by: java.lang.NoClassDefFoundError:     Class not found using the boot class loader; no stack available

我是编译 Android 源代码的新手,所以这可能很明显,但我应该为我的特定设备构建而不是使用 lunch full-eng

对于这个问题的任何帮助将不胜感激。

【问题讨论】:

    标签: android-softkeyboard classnotfoundexception android-source android-input-method


    【解决方案1】:

    在构建平台应用时,其中大部分都已预先优化。通过添加 WITH_DEXPREOPT := false,它将构建带有 dex 文件的 apk。

    验证您推送到设备的 LatinIME.apk 中是否包含 classes.dex 文件(解压缩 -l)。如果没有,请将 WITH_DEXPREOPT 添加到 LatinIME 的 Android.mk 文件。

    【讨论】:

    • LatinIME.apk 中没有 classes.dex 文件,所以今晚我会试一试。看起来它希望通过此更改进行全面重建,并且不会让我 mm LatinIME 模块 build/core/main.mk:528: WITH_DEXPREOPT has been modified: false build/core/main.mk:528: previous value: true build/core/main.mk:528: *** The following variables have been changed: WITH_DEXPREOPT. Stop.
    • 我会接受这个答案。我最终不得不运行make -j WITH_DEXPREOPT=false,因为我无法让编译器停止抱怨我之前提到的变量被更改。虽然 LatinIME 仍在抛出错误,但我相信它们与这个最初的问题无关。后续问题可以找here
    猜你喜欢
    • 2015-03-16
    • 2014-10-18
    • 2015-03-22
    • 1970-01-01
    • 2019-01-05
    • 2010-12-09
    • 1970-01-01
    • 2013-01-18
    相关资源
    最近更新 更多