java - 自定义类加载失败,出现 java.lang.IllegalAccessError : Class ref in pre-verified class resolved to unexpected implementation

标签 java android classloader

我正在尝试调整 http://android-developers.blogspot.de/2011/07/custom-class-loading-in-dalvik.html 中的示例根据我的需要。为此,我设置了 3 个项目:

类加载测试: 标准android应用项目,包含上面链接中MainActivity的源码,稍作调整(将DexClassLoader业务移到名为“AndroidClassLoader”的类中),引用下面的“iface”项目

界面: 一个仅包含一个接口(interface)的 android 库项目,该接口(interface)只有一个函数(“getMessage()”)返回一个字符串

可加载: 一个标准的 android 应用程序项目也引用了“iface”库,其中仅包含一个实现该非常简单的接口(interface)的类和一个调整构建过程的 custom_rules.txt 文件:

<?xml version="1.0" encoding="UTF-8"?>
<project name="BuildLoadableDex" default="debug">
    <target name="-dex" depends="-compile, -post-compile, -obfuscate">
        <echo level="info">Custom -dex target</echo>
        <property name="out.dex.input.absolute.dir" value="${out.classes.absolute.dir}" />
        <dex executable="${dx}"
                output="${intermediate.dex.file}"
                dexedlibs="${out.dexed.absolute.dir}"
                nolocals="@{nolocals}"
                forceJumbo="${dex.force.jumbo}"
                disableDexMerger="${dex.disable.merger}"
                verbose="${verbose}">
            <path path="${out.dex.input.absolute.dir}"/>
        </dex>
    </target>

    <target name="-package" depends="-dex, -package-resources">
        <echo level="info">Custom -package target</echo>
        <jar destfile="${out.absolute.dir}/${ant.project.name}.jar"
            basedir="${out.absolute.dir}"
            includes="${dex.file.name}" />
    </target>
</project>

所以这实际上只是修改了 -dex 目标以从 classes.dex 文件中删除库类(通过 dexdump 验证未显示界面)并更改了 -package 目标以输出 jar 文件而不是 apk。

然后我将 loadable.jar 文件复制到 classloadingtest/assets 并构建该 apk 文件。

一切都编译正常,但是当运行并触发类加载时,我得到以下堆栈跟踪:

W/dalvikvm(14393): Class resolved by unexpected DEX: Lloadable/Test;(0x4294b620):0x5a6a7000 ref [Lclassloading/iface/LoadableClass;] Lclassloading/iface/LoadableClass;(0x42912fb8):0x5a4bf000
W/dalvikvm(14393): (Lloadable/Test; had used a different Lclassloading/iface/LoadableClass; during pre-verification)
I/dalvikvm(14393): Failed resolving Lloadable/Test; interface 6 'Lclassloading/iface/LoadableClass;'
W/dalvikvm(14393): Link of class 'Lloadable/Test;' failed
D/AndroidRuntime(14393): Shutting down VM
W/dalvikvm(14393): threadid=1: thread exiting with uncaught exception (group=0x41c622a0)
E/AndroidRuntime(14393): FATAL EXCEPTION: main
E/AndroidRuntime(14393): java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
E/AndroidRuntime(14393):        at dalvik.system.DexFile.defineClass(Native Method)
E/AndroidRuntime(14393):        at dalvik.system.DexFile.loadClassBinaryName(DexFile.java:211)
E/AndroidRuntime(14393):        at dalvik.system.DexPathList.findClass(DexPathList.java:315)
E/AndroidRuntime(14393):        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:58)
E/AndroidRuntime(14393):        at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
E/AndroidRuntime(14393):        at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
E/AndroidRuntime(14393):        at classloading.loading.AndroidClassLoader.findClass(AndroidClassLoader.java:56)
E/AndroidRuntime(14393):        at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
E/AndroidRuntime(14393):        at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
E/AndroidRuntime(14393):        at classloading.loading.AndroidClassLoader.loadClass(AndroidClassLoader.java:37)
E/AndroidRuntime(14393):        at classloading.ClassLoadingTest$1.onClick(ClassLoadingTest.java:60)
E/AndroidRuntime(14393):        at android.view.View.performClick(View.java:4211)
E/AndroidRuntime(14393):        at android.view.View$PerformClick.run(View.java:17267)
E/AndroidRuntime(14393):        at android.os.Handler.handleCallback(Handler.java:615)
E/AndroidRuntime(14393):        at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime(14393):        at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(14393):        at android.app.ActivityThread.main(ActivityThread.java:4898)
E/AndroidRuntime(14393):        at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(14393):        at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(14393):        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
E/AndroidRuntime(14393):        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
E/AndroidRuntime(14393):        at dalvik.system.NativeStart.main(Native Method)

我确实明白这意味着 LoadableClass 接口(interface)“似乎”存在两次但有所不同,但我只是不明白这是怎么发生的,看到 APK(类加载测试)和 loadable.jar 使用确切的用于编译的相同库项目,因此我不知道如何修复此错误。

请随时请求编辑更多代码,我只是不知道这里有什么用处,也不想粘贴一切

最佳答案

愚蠢解决了,我一直在尝试加载旧版本的 loadable.jar。把它留在这里,这样其他人可能会受益,而不会浪费那么多时间。

关于java - 自定义类加载失败,出现 java.lang.IllegalAccessError : Class ref in pre-verified class resolved to unexpected implementation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15761081/

相关文章:

java - 如何查询 Firebase 以执行以下操作?

java - 行过滤器在单元格更新事件中无法按预期工作

java - 如何在 Java 中创建数学序列?

java - 通过 Class.forName 从 Java 加载 JRuby 类

java - 在java中的windows下根据给定的COMx名称查找com端口的 "FriendlyName"

android - 无法设置所选抽屉项目的背景颜色

Android 4.2 with 4 MediaPlayers = "Can' t play this video"

java - 如何/在哪里在云上托管 Java 服务器?

java - 动态程序更新、运行时编译和类加载器

java - 当 Thread.currentThread().getContextClassLoader() 返回 null 时,这是怎么回事?