0

我已经开发了一段时间的应用程序(在这里),我正在尝试在我的 Android 设备和模拟器上进行这两项测试。

目前我已经在 Travis 上进行了构建,所有测试都运行良好。此外,我设置了一个本地模拟器,可以正常运行。我的物理设备(Moto X)也可以很好地运行一切,但只有在 Dalvik 上时才可以。一旦我切换到 ART,我就会收到以下错误:

11-11 15:28:54.013    6259-6259/org.bspeice.minimalbible E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: org.bspeice.minimalbible, PID: 6259
    java.lang.NoClassDefFoundError: org.jdom2.xpath.jaxen.JDOMCoreNavigator
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:305)
            at android.test.ClassPathPackageInfoSource.createPackageInfo(ClassPathPackageInfoSource.java:88)
            at android.test.ClassPathPackageInfoSource.access$000(ClassPathPackageInfoSource.java:39)
            at android.test.ClassPathPackageInfoSource$1.load(ClassPathPackageInfoSource.java:50)
            at android.test.ClassPathPackageInfoSource$1.load(ClassPathPackageInfoSource.java:47)
            at android.test.SimpleCache.get(SimpleCache.java:31)
            at android.test.ClassPathPackageInfoSource.getPackageInfo(ClassPathPackageInfoSource.java:72)
            at android.test.ClassPathPackageInfo.getSubpackages(ClassPathPackageInfo.java:48)
            at android.test.ClassPathPackageInfo.addTopLevelClassesTo(ClassPathPackageInfo.java:61)
            at android.test.ClassPathPackageInfo.getTopLevelClassesRecursive(ClassPathPackageInfo.java:55)
            at android.test.suitebuilder.TestGrouping.testCaseClassesInPackage(TestGrouping.java:156)
            at android.test.suitebuilder.TestGrouping.addPackagesRecursive(TestGrouping.java:117)
            at android.test.suitebuilder.TestSuiteBuilder.includePackages(TestSuiteBuilder.java:102)
            at android.test.InstrumentationTestRunner.onCreate(InstrumentationTestRunner.java:366)
            at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4400)
            at android.app.ActivityThread.access$1500(ActivityThread.java:139)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1270)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5086)
            at java.lang.reflect.Method.invoke(Native Method)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)

如果有帮助,这里有一个完整的会话跟踪。

所以我的问题是:有什么理由这将是 ART 而不是 Dalvik 的问题?我根本没有更改应用程序构建过程,唯一似乎有所作为的变量是 Dalvik/ART。该应用程序本身运行良好,只是测试有错误。

4

1 回答 1

0

看起来 ART 没有找到你的类,ClassNotFoundException 被抛出。我不精通java或cpp,但在我阅读ART时,它在语法上要严格得多。Dalvik 将接受点或斜杠作为分隔符,ART 仅斜杠等。我有一堆在 Dalvik 上运行良好的东西,但在 ART/Android-5.0.x 上掉下来并死掉了。您自己解决了这个问题吗?在接下来的几周内,我将尝试确定我的应用程序出了什么问题,但我怀疑与 Dalvik 相比,ART 正在执行更激进的内存管理垃圾收集。如果您解决了问题,请张贴说明您所做的事情的说明。

于 2015-04-08T06:57:49.580 回答