2

我正在尝试通过从原始文件夹中读取 txt 文件来为我的应用程序创建一个整数数组。txt 的每一行都有编号,如下所示:

测试.txt

1
3
4
5
6
2
-9
...

我的数组是这样的Integer[] vector = {1,2,3,4,5,6,2,-9,...}

我正在部署的代码(实际上是在点击回调方法中):

public void plotSPLinfBaffle(View v) {
    List<Integer> vector = new ArrayList<Integer>();

    InputStream in = getResources().openRawResource(R.raw.test);
    Scanner sc = new Scanner(new InputStreamReader(in));

    while(sc.hasNext()){

        vector.add(Integer.parseInt(sc.nextLine()));
    }

    Log.d("clicked" , sc.nextLine());

    Integer[] splVector = vector.toArray(new Integer[0]);
}

你看,我不断收到这个运行时错误和 logcat 消息:

02-21 14:04:35.599: D/AndroidRuntime(19925): Shutting down VM
02-21 14:04:35.599: W/dalvikvm(19925): threadid=1: thread exiting with uncaught exception (group=0x40018578)
02-21 14:04:35.619: E/AndroidRuntime(19925): FATAL EXCEPTION: main
02-21 14:04:35.619: E/AndroidRuntime(19925): java.lang.IllegalStateException: Could not execute method of the activity
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.view.View$1.onClick(View.java:2144)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.view.View.performClick(View.java:2485)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.view.View$PerformClick.run(View.java:9080)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.os.Handler.handleCallback(Handler.java:587)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.os.Handler.dispatchMessage(Handler.java:92)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.os.Looper.loop(Looper.java:130)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.app.ActivityThread.main(ActivityThread.java:3687)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at java.lang.reflect.Method.invokeNative(Native Method)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at java.lang.reflect.Method.invoke(Method.java:507)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at dalvik.system.NativeStart.main(Native Method)
02-21 14:04:35.619: E/AndroidRuntime(19925): Caused by: java.lang.reflect.InvocationTargetException
02-21 14:04:35.619: E/AndroidRuntime(19925):    at java.lang.reflect.Method.invokeNative(Native Method)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at java.lang.reflect.Method.invoke(Method.java:507)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at android.view.View$1.onClick(View.java:2139)
02-21 14:04:35.619: E/AndroidRuntime(19925):    ... 11 more
02-21 14:04:35.619: E/AndroidRuntime(19925): Caused by: java.util.NoSuchElementException
02-21 14:04:35.619: E/AndroidRuntime(19925):    at java.util.Scanner.nextLine(Scanner.java:1417)
02-21 14:04:35.619: E/AndroidRuntime(19925):    at com.soulmagnet.speakerparametrix2.PlotInfBaffle.plotSPLinfBaffle(PlotInfBaffle.java:136)
02-21 14:04:35.619: E/AndroidRuntime(19925):    ... 14 more

尽管如此,当在调试模式下放置断点时:

22 vector.add(Integer.parseInt(sc.nextLine()));

我可以在每次迭代中看到向量变量,但是当它完成填充某些东西时会杀死我的活动......

我只是不明白出了什么问题,这就是我寻求帮助的原因!

先感谢您!

4

3 回答 3

3

仔细查看堆栈跟踪和Scanner.nextLine()方法的文档。

在此循环中,您正在吃掉输入文件中的所有行:

while (sc.hasNext()) {
    vector.add(Integer.parseInt(sc.nextLine()));
}

但是,在这一行中:

Log.d("clicked" , sc.nextLine());

你调用nextLine()一个已经结束的输入。根据以下文件Scanner.nextLine()

抛出:

NoSuchElementException - 如果没有找到行

此调用导致Scanner抛出NoSuchElementException。只需删除该Log.d()行 - 或记住循环中的最后一个元素,然后将其值记录到 LogCat(如果这是您的意图)。

于 2013-02-21T12:19:39.017 回答
2

在您的while-loop 之后,sc不再包含行(因此循环退出)。

后来你有

 Log.d("clicked" , sc.nextLine());

这试图抓住另一行(不再存在),导致错误:

E/AndroidRuntime(19925): Caused by: java.util.NoSuchElementException
E/AndroidRuntime(19925):    at java.util.Scanner.nextLine(Scanner.java:1417)
E/AndroidRuntime(19925):    at com.soulmagnet.speakerparametrix2.PlotInfBaffle.plotSPLinfBaffle(PlotInfBaffle.java:136)

(这在完整的错误日志中有些隐藏)

因此,删除该行,它应该可以正常工作。

于 2013-02-21T12:16:17.647 回答
0

您在日志中看到“点击”了吗?

如果可以的话,在打印此日志之前一切都很好。

日志中有趣的部分;

14:04:35.619: E/AndroidRuntime(19925): ... 11 更多 02-21 14:04:35.619: E/AndroidRuntime(19925):由: java.util.NoSuchElementException 02-21 14:04:35.619 : E/AndroidRuntime(19925): at java.util.Scanner.nextLine (Scanner.java:1417) 02-21 14:04:35.619: E/AndroidRuntime(19925): at com.soulmagnet.speakerparametrix2.PlotInfBaffle.plotSPLinfBaffle( PlotInfBaffle.java:136) 02-21 14:04:35.619: E/AndroidRuntime(19925): ... 14 更多

Scanner的文档 说当没有新行时将引发此异常。

这是你的问题

Log.d("clicked" , sc.nextLine()); 
于 2013-02-21T12:19:21.533 回答