android – HelloWorld无法在dalvikvm下运行

我正在尝试 https://android.googlesource.com/platform/dalvik/+/gingerbread/docs/hello-world.html的Hello World示例

但是,我的Foo程序没有运行; dalvikvm抱怨如下:

Dalvik VM unable to locate class ‘Foo’
java.lang.NoClassDefFoundError: Foo
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.classNotFoundException: Foo in loader dalvik.system.PathClassLoader[/mnt/sdcard/foo.jar]
at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
at java.lang.classLoader.loadClass(ClassLoader.java:573)
at java.lang.classLoader.loadClass(ClassLoader.java:532)
… 1 more

在dalvikvm调用期间,Logcat提供了更多信息:

D/dalvikvm( 1361): creating instr width table
E/dalvikvm( 1361): Can’t open dex cache ‘/data/dalvik-cache/mnt@sdcard@foo.jar@classes.dex’: No such file or directory
I/dalvikvm( 1361): Unable to open or create cache for /mnt/sdcard/foo.jar (/data
/dalvik-cache/mnt@sdcard@foo.jar@classes.dex)
W/dalvikvm( 1361): threadid=1: thread exiting with uncaught exception (group=0x4
001e9a8)

有没有人知道我做错了什么?

解决方法

这篇文章的作者Andy McFadden给了我一个提示

It’s trying to create a .odex file in /data/dalvik-cache. You’ll
need to be running as root,or have an unprotected
/data/dalvik-cache.

一旦我植入我的设备(例如使用SuperOneClick),它就可以了!

@domen的评论:你实际上不必是root.您可以设置ANDROID_DATA环境变量,它会将缓存放在那里.即mkdir / data / local / tmp / dalvik-cache,export ANDROID_DATA = / data / local / tmp.

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...