0

我的应用程序很大程度上基于 OpenCV 示例(带摄像头的示例 2)链接到 OpenCV 2.4.0。经过一个月左右的无故障工作后,我突然遇到了可怕的“Dalvik error 1”问题。当通常的修复不起作用时,我决定使用相同的源文件从头开始构建一个新项目,希望能解决问题......

它可以构建,但在启动时崩溃。这是控制台内容:

06-07 14:01:01.383: D/dalvikvm(20915): Trying to load lib /data/data/barry.opencvdemo/lib/libopencv_java.so 0x4051c988
06-07 14:01:02.204: D/dalvikvm(20915): Added shared lib /data/data/barry.opencvdemo/lib/libopencv_java.so 0x4051c988
06-07 14:01:02.354: D/AndroidRuntime(20915): Shutting down VM
06-07 14:01:02.354: W/dalvikvm(20915): threadid=1: thread exiting with uncaught exception (group=0x4001d5a0)
06-07 14:01:02.374: E/AndroidRuntime(20915): FATAL EXCEPTION: main
06-07 14:01:02.374: E/AndroidRuntime(20915): java.lang.RuntimeException: Unable to start activity ComponentInfo{barry.opencvdemo/barry.opencvdemo.Sample2NativeCamera}: java.lang.NullPointerException
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1872)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1893)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread.access$1500(ActivityThread.java:135)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1054)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.os.Handler.dispatchMessage(Handler.java:99)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.os.Looper.loop(Looper.java:150)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread.main(ActivityThread.java:4385)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at java.lang.reflect.Method.invokeNative(Native Method)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at java.lang.reflect.Method.invoke(Method.java:507)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:607)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at dalvik.system.NativeStart.main(Native Method)
06-07 14:01:02.374: E/AndroidRuntime(20915): Caused by: java.lang.NullPointerException
06-07 14:01:02.374: E/AndroidRuntime(20915):    at barry.opencvdemo.Sample2NativeCamera.onCreate(Sample2NativeCamera.java:47)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1072)
06-07 14:01:02.374: E/AndroidRuntime(20915):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1836)
06-07 14:01:02.374: E/AndroidRuntime(20915):    ... 11 more

一切似乎都在正确的位置和正确的名称,但有些东西不起作用。以上内容是否足以让某人指出我遗漏的一些明显的东西,或者我应该发布一些源代码?代码本身正在工作......这是关于构建的设置或我担心的链接。

当众神对整个 Dalvik Error 1 业务采取行动时,我会非常高兴。

非常感谢您的任何建议。

4

2 回答 2

0

try catch block在代码周围放置onCreatea 并在 catch 中放置一个断点。您将捕获异常。从异常日志看来,您正在使用尚未初始化的对象/变量。

于 2012-06-07T15:29:57.020 回答
0

当您的应用遇到意外错误并且不知道如何响应时,就会发生这种情况。正如之前所说,您可以用 try/catch 块包围部分代码。

而且:06-07 14:01:02.374: E/AndroidRuntime(20915): java.lang.RuntimeException: Unable to start activity ComponentInfo{barry.opencvdemo/barry.opencvdemo.Sample2NativeCamera}: java.lang.NullPointerException

这是解决您遇到的问题的线索。NullPointerException 意味着一个类在某处期待一个对象,但得到了一个空值。

您可以尝试使用 try/catch 包围与它相关的代码部分,或者只是放置一些 System.out.println() 以查看运行停止工作的位置。

希望这可以帮助!

于 2012-06-07T15:47:56.200 回答