我有一个 while 循环,它将使用缓冲读取器读取的元素添加到 ArrayList 中。循环工作正常,除了完成后,应用程序似乎没有继续前进。相关代码为:
int ctr = 1;
while((test = bf.readLine()) != null)
{
Log.i(TAG, test);
users.add(test);
Log.i(TAG, "" + (ctr++));
}
Log.i(TAG, "Loop done.");
循环中的两个日志语句各执行 4 次,这是正常行为。但是,循环后面的语句不会执行。就好像被卡住了一样。我很确定它也不会进入循环,因为里面的两个日志语句也不再执行。
bf是BufferedReader,users是ArrayList。
LogCat 输出:
08-04 01:35:37.472: I/UM(2937): UserInfo{0:Primary:3}
08-04 01:35:37.472: I/UM(2937): 1
08-04 01:35:37.476: I/UM(2937): UserInfo{1:Test1:0}
08-04 01:35:37.476: I/UM(2937): 2
08-04 01:35:37.476: I/UM(2937): UserInfo{2:test2:0}
08-04 01:35:37.480: I/UM(2937): 3
08-04 01:35:37.480: I/UM(2937): UserInfo{3:testxyz:0}
08-04 01:35:37.480: I/UM(2937): 4
有人知道我的(可能是愚蠢的)错误是什么吗?
最佳答案
您的代码在线上阻塞:
while((test = bf.readLine()) != null)
这样做是因为向 bf
提供数据的流永远不会被关闭。
(这个答案不是我的,它只是评论中的一个快速总结。)
关于java - 循环结束,但没有结束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11802634/