0

たった一行のファイルです。

.size() を他の何か (スペースの文字列に追加するなど) で呼び出すと、何かが吐き出されますが、関数を単独で呼び出すとクラッシュするのはなぜですか?

int pos =0;
List<List<String>> mine = new ArrayList<List<String>>();
while((nextLine = csvReader.readLine()) != null) {
    mine.add(pos,new ArrayList <String>());
    for (String token : nextLine.split(",")) {

        //get next token and store it in the list
        mine.get(pos).add(token); 
        //Toast.makeText(MainActivity.this,mine.size() + " " + mine.get(pos).size(), Toast.LENGTH_SHORT).show();
    }

    //Toast.makeText(MainActivity.this, " " + mine.get(pos).size(), Toast.LENGTH_SHORT).show(); //doesn't crash here

    //  mine_end= mine.get(pos).size(); //crash here

    pos ++;
}

エラーの最新のスタック トレースは次のとおりです。

07-17 15:52:44.987: E/wpa_supplicant(29035): 進行中のスキャン アクション... 07-17 15:52:46.989: E/wpa_supplicant(29035): 進行中のスキャン アクション... 07-17 15:52 :48.991: E/wpa_supplicant(29035): 進行中のスキャン アクション... 07-17 15:52:49.061: E/AndroidRuntime(1249): 致命的な例外: メイン 07-17 15:52:49.061: E/AndroidRuntime(1249 ): android.content.res.Resources$NotFoundException: 文字列リソース ID #0x1 07-17 15:52:49.061: E/AndroidRuntime(1249): at android.content.res.Resources.getText(Resources.java:221) 07-17 15:52:49.061: E/AndroidRuntime(1249): android.widget.Toast.makeText(Toast.java:284) 07-17 15:52:49.061: E/AndroidRuntime(1249): com. jimmyc.summer.wificollection.MainActivity.match(MainActivity.java:137) 07-17 15:52:49.061: E/AndroidRuntime(1249): com.jimmyc.summer.wificollection.MainActivity.access$2(MainActivity.java: 91) 07-17 15:52:49.061: E/AndroidRuntime(1249): com.jimmyc.summer.wificollection.MainActivity$2$1$1.run(MainActivity.java:383) 07-17 15:52:49.061: E/AndroidRuntime(1249): Android で。 os.Handler.handleCallback(Handler.java:587) 07-17 15:52:49.061: E/AndroidRuntime(1249): android.os.Handler.dispatchMessage(Handler.java:92) 07-17 15:52: 49.061: E/AndroidRuntime(1249): android.os.Looper.loop(Looper.java:130) 07-17 15:52:49.061: E/AndroidRuntime(1249): android.app.ActivityThread.main(ActivityThread) .java:3691) 07-17 15:52:49.061: E/AndroidRuntime(1249): java.lang.reflect.Method.invokeNative(ネイティブ メソッド) 07-17 15:52:49.061: E/AndroidRuntime(1249) : java.lang.reflect.Method.invoke(Method.java:507) 07-17 15:52:49.061: E/AndroidRuntime(1249): com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit .java:907) 07-17 15:52:49.061: E/AndroidRuntime (1249): com.android.internal.os.ZygoteInit.main (ZygoteInit.java:665) 07-17 15:52:49.061: E/AndroidRuntime ( 1249): dalvik.system.NativeStart.main (ネイティブ メソッド) 07-17 15:52:49.071: E/(306): Dumpstate > /data/log/dumpstate_app_error

4

2 に答える 2

2

mine.get(pos)が返される可能性が非常に高いnullため、 aNullPointerExceptionが発生します。posリスト内の各位置が初期化されていることを確認してください。

于 2012-07-17T21:29:53.137 に答える
0

エラーはまったく関係のないものでした。トースト メッセージを使用してデバッグするべきではないと思います。この場合、タイミングに影響し、.size() がエラーの原因であると信じるようになりました。

于 2012-07-18T04:37:36.773 に答える