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): at 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): at java.lang.reflect.Method.invokeNative(Native Method) 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(Native Method) 07-17 15:52:49.071: E/(306): Dumpstate > /data/log/dumpstate_app_error

4

2 回答 2

2

很可能mine.get(pos)正在返回null,因此NullPointerException发生了 a 。确保您已初始化pos列表中的每个位置。

于 2012-07-17T21:29:53.137 回答
0

这个错误是完全不相关的。我想我不应该使用 Toast 消息进行调试。在这种情况下,它影响了时间并让我相信 .size() 导致了错误。

于 2012-07-18T04:37:36.773 回答