0

次のエラーログを取得しています:

05-29 20:57:29.886: D/AndroidRuntime(359): Shutting down VM
05-29 20:57:29.896: W/dalvikvm(359): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
05-29 20:57:29.896: E/AndroidRuntime(359): Uncaught handler: thread main exiting due to uncaught exception
05-29 20:57:29.906: E/AndroidRuntime(359): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dd.qsg/com.dd.qsg.QSGActivity}: java.lang.NullPointerException
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.os.Handler.dispatchMessage(Handler.java:99)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.os.Looper.loop(Looper.java:123)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread.main(ActivityThread.java:4363)
05-29 20:57:29.906: E/AndroidRuntime(359):  at java.lang.reflect.Method.invokeNative(Native Method)
05-29 20:57:29.906: E/AndroidRuntime(359):  at java.lang.reflect.Method.invoke(Method.java:521)
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
05-29 20:57:29.906: E/AndroidRuntime(359):  at dalvik.system.NativeStart.main(Native Method)
05-29 20:57:29.906: E/AndroidRuntime(359): Caused by: java.lang.NullPointerException
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.dd.qsg.DatabaseHandler.getLongestSmoke(DatabaseHandler.java:85)
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.dd.qsg.QSGActivity.onCreate(QSGActivity.java:40)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-29 20:57:29.906: E/AndroidRuntime(359):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
05-29 20:57:29.906: E/AndroidRuntime(359):  ... 11 more
05-29 20:57:29.926: I/dalvikvm(359): threadid=7: reacting to signal 3
05-29 20:57:29.926: E/dalvikvm(359): Unable to open stack trace file '/data/anr/traces.txt': Permission denied
05-29 20:57:31.206: I/Process(359): Sending signal. PID: 359 SIG: 9

私はこれを修正する方法がわかりません。何かを修正する必要があると私に言っているのはどこですか?

DatabaseHandler.javaの85行目:

theCount = context.getResources().getString(R.string.na);

ここに関数全体があります:

public String getLongestSmoke(Context context) {
    String theCount = "";  
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.rawQuery("SELECT millis FROM records ORDER BY CAST(millis as SIGNED) DESC", null);

    if (cursor.getCount() > 0) {
        cursor.moveToFirst();    
        theCount = cursor.getString(0);
    }
    else {
        theCount = context.getResources().getString(R.string.na);
    }

    cursor.close();        
    return humanTime(theCount);
}

この関数を使用するメインアクティビティのonCreateメソッドの行は次のとおりです。

    longestGone.setText(getString(R.string.longest_gone) + " " +  db.getLongestSmoke(null));

以前はnullでしたが、突然停止しました。私はそれを作ることになっていますか?

DatabaseHandlerクラスのonCreateに次の変更を加えるまで、これは正常に機能していました。

    String CREATE_ACHIEVEMENTS_TABLE = "CREATE TABLE achievements ("
             + "id INTEGER PRIMARY KEY,"
             + "name VARCHAR,"
             + "type VARCHAR,"
             + "value VARCHAR,"
             + "completed VARCHAR"
             + ")";              

    db.execSQL(CREATE_ACHIEVEMENTS_TABLE);      

    db.execSQL("insert into achievements (name, type, value, completed) values ('30 minutes', 'time', '1800000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('1 hour', 'time', '3600000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('2 hours', 'time', '7200000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('6 hours', 'time', '21600000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('12 hours', 'time', '43200000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('1 day', 'time', '86400000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('2 days', 'time', '172800000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('1 week', 'time', '604800000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('2 weeks', 'time', '1209600000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('1 month', 'time', '2592000000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('2 months', 'time', '5184000000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('6 months', 'time', '15552000000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('1 year', 'time', '31536000000', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('Set a record', 'milestone', '', 'no')");
    db.execSQL("insert into achievements (name, type, value, completed) values ('Beat top record', 'milestone', '', 'no')");

私もこれをonUpgradeに追加しました:

    db.execSQL("DROP TABLE IF EXISTS achievements");
4

3 に答える 3

4

ここ:

05-29 20:57:29.906: E/AndroidRuntime(359): Caused by: java.lang.NullPointerException
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.dd.qsg.DatabaseHandler.getLongestSmoke(DatabaseHandler.java:85)

ファイル DatabaseHelper.java の 85 行目に、アクセスできない null 値があることをお伝えします。

編集:

編集した投稿によると、次の行です。

theCount = context.getResources().getString(R.string.na);

contextnull であり、NPE を引き起こします。

于 2012-05-29T21:02:03.193 に答える
3
05-29 20:57:29.906: E/AndroidRuntime(359): Caused by: java.lang.NullPointerException
05-29 20:57:29.906: E/AndroidRuntime(359):  at com.dd.qsg.DatabaseHandler.getLongestSmoke(DatabaseHandler.java:85)

あなたの手がかりがあります。DatabaseHandler.java の 85 行目の何かが、null 参照を逆参照しようとしています。

contextあなたの編集に照らして、それはnullだと思います。

そして、あなたの2番目の編集に照らして:

db.getLongestSmoke(null)

nullパラメータとして渡していcontextます。Context代わりに有効な値を渡します。試す:

db.getLongestSmoke(this)

whereは、この呼び出しの発信this元のアクティビティです。onCreate

于 2012-05-29T21:02:10.217 に答える
-3

DatabaseHandler が null のようです

于 2012-05-29T21:02:46.903 に答える