android - 应用程序在创建 DatePickerDialog 期间崩溃

标签 android eclipse debugging datepicker illegalargumentexception

我对 Android 平台上的编程完全陌生,但我有兴趣了解更多。目前,我正在借助分步手册来执行此操作。只是为了让自己熟悉编程环境。我了解 Java 语言,但我不会说我擅长它。

至于这个问题,我正在创建一个适用于 Android 设备的简单问答游戏。在设置屏幕上,我为用户生日使用 DatePickerDialog。只有当我在我的 Android 设备 (Samsung Galaxy S i9000) 或模拟器上运行它时,它才会在尝试弹出 DatePickerDialog 时崩溃。

我使用的代码是:

final TextView dob = (TextView) findViewById(R.id.TextView_DOB_Info);
DatePickerDialog dateDialog = new DatePickerDialog(this, new DatePickerDialog.OnDateSetListener() {
    public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
        Time dateOfBirth = new Time();
        dateOfBirth.set(dayOfMonth, monthOfYear, year);
        long dtDob = dateOfBirth.toMillis(true);
        dob.setText(DateFormat.format("MMMM dd, yyyy", dtDob));
        Editor editor = mGameSettings.edit();
        editor.putLong(GAME_PREFERENCES_DOB, dtDob);
        editor.commit();
    }
}, 0, 0, 0);
return dateDialog;

任何人都可以看到我在这里做错了什么吗?运行时,我在该方法中得到 IllegalArgumentException。我正在使用 Eclipse 为 Android 编程,但我对这个程序也很陌生(我更熟悉 Netbeans),我仍在尝试弄清楚如何通过 Android 应用程序正确调试。

如果有人能提供帮助,将不胜感激! 亲切的问候, 弗洛里斯

编辑:根据要求,我添加了 LogCat 行:

09-16 18:42:22.386: ERROR/AndroidRuntime(20074): FATAL EXCEPTION: main
09-16 18:42:22.386: ERROR/AndroidRuntime(20074): java.lang.IllegalArgumentException: current should be >= start and <= end
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.widget.NumberPicker.setCurrent(NumberPicker.java:362)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.widget.DatePicker.updateDaySpinner(DatePicker.java:487)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.widget.DatePicker.updateSpinners(DatePicker.java:471)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.widget.DatePicker.init(DatePicker.java:467)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.DatePickerDialog.<init>(DatePickerDialog.java:154)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.DatePickerDialog.<init>(DatePickerDialog.java:113)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at com.androidbook.triviaquiz.QuizSettingsActivity.onCreateDialog(QuizSettingsActivity.java:404)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.Activity.onCreateDialog(Activity.java:2482)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.Activity.createDialog(Activity.java:882)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.Activity.showDialog(Activity.java:2557)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.Activity.showDialog(Activity.java:2524)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at com.androidbook.triviaquiz.QuizSettingsActivity$4.onClick(QuizSettingsActivity.java:367)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.view.View.performClick(View.java:2538)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.view.View$PerformClick.run(View.java:9152)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.os.Handler.handleCallback(Handler.java:587)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.os.Handler.dispatchMessage(Handler.java:92)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.os.Looper.loop(Looper.java:123)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at android.app.ActivityThread.main(ActivityThread.java:3687)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at java.lang.reflect.Method.invokeNative(Native Method)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at java.lang.reflect.Method.invoke(Method.java:507)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
09-16 18:42:22.386: ERROR/AndroidRuntime(20074):     at dalvik.system.NativeStart.main(Native Method)
09-16 18:42:22.414: ERROR/(14248): Dumpstate > /data/log/dumpstate_app_error

当我通读它时,我注意到问题出在 NumberPicker 类中。只是为了确定,他在这里期望的数字是什么意思?

最佳答案

我从未使用过 DatePickerDialog 但据我所知,您正在使用 0, 0, 0 作为年份、月份和日期月份参数。将它们设置为合乎逻辑的值,例如 2011, 9, 16,看看是否有帮助。

编辑 实际上,您可能必须使用 10 表示九月,因为我认为它符合 Calendar 使用的 0-11 月份数字。

关于android - 应用程序在创建 DatePickerDialog 期间崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7447814/

相关文章:

c# - VS2013专业本地64位调试MSVSMON问题

java - 迭代列表对象内的对象

android - 响应式设计/媒体查询

android - 了解 appcompact values-v11/themes_base.xml 错误

css - Bootstrap 中的 padding-bottom css 错误?

debugging - VS2008 : Unable to start debugging, 远程调试监视器已关闭

android - Cordova 2.7.0 PushPlugin "cordova cannot be resolved"和 "ctx cannot be resolved"

android - 无法在 SD 卡上写入文件

python - Pydev 有选择地运行单元测试

android - 如何在 Eclipse 中调试 Android/Java