是的,没错。尽管引入了一些错误的代码,但该应用程序仍在继续运行。我对 Android 和 Eclipse 开发真的很陌生,所以我想知道是否有一些设置导致应用程序不崩溃?我试图导致崩溃的原因是我可以测试一些崩溃报告代码。
这是我创建异常的方式。在我的一个按钮事件处理程序中,我添加了这一行:
int i = 1 / 0; // Divide by zero is bad!
这是遇到上述行后的 LogCat 输出:
04-25 15:50:39.880: W/System.err(2786): java.lang.reflect.InvocationTargetException
04-25 15:50:39.880: W/System.err(2786): at java.lang.reflect.Method.invokeNative(Native Method)
04-25 15:50:39.880: W/System.err(2786): at java.lang.reflect.Method.invoke(Method.java:507)
04-25 15:50:39.880: W/System.err(2786): at com.mystuff.android.ReflectiveAction.run(Unknown Source)
04-25 15:50:39.880: W/System.err(2786): at com.mystuff.android.Command.onClick(Unknown Source)
04-25 15:50:39.890: W/System.err(2786): at android.view.View.performClick(View.java:2532)
04-25 15:50:39.890: W/System.err(2786): at android.view.View$PerformClick.run(View.java:9293)
04-25 15:50:39.890: W/System.err(2786): at android.os.Handler.handleCallback(Handler.java:587)
04-25 15:50:39.890: W/System.err(2786): at android.os.Handler.dispatchMessage(Handler.java:92)
04-25 15:50:39.890: W/System.err(2786): at android.os.Looper.loop(Looper.java:143)
04-25 15:50:39.890: W/System.err(2786): at android.app.ActivityThread.main(ActivityThread.java:4263)
04-25 15:50:39.890: W/System.err(2786): at java.lang.reflect.Method.invokeNative(Native Method)
04-25 15:50:39.890: W/System.err(2786): at java.lang.reflect.Method.invoke(Method.java:507)
04-25 15:50:39.890: W/System.err(2786): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-25 15:50:39.890: W/System.err(2786): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-25 15:50:39.890: W/System.err(2786): at dalvik.system.NativeStart.main(Native Method)
04-25 15:50:39.890: W/System.err(2786): Caused by: java.lang.ArithmeticException: divide by zero
04-25 15:50:39.890: W/System.err(2786): at com.mystuff.theapp.HomePage.evSurprise(HomePage.java:209)
04-25 15:50:39.890: W/System.err(2786): ... 15 more
感谢您的任何帮助!
编辑 - 这是带有错误代码行的整个事件处理程序:
public void evSurprise () {
int i = 1 / 0;
cpanel.animateGoButtonWhole();
cpanel.showThrobber();
Helper.startActivity( this, Actions.VENUE, Actions.SEARCH, false );
}
顺便说一句,此代码是由我们公司的外部承包商编写的。我是一名正在尝试了解 java 和 Android 开发的 Objective-C 程序员。由于我对这段代码的了解有限,很可能存在一个我不知道的异常处理程序。如果是这种情况,我应该寻找什么?