我有一个数据文件,在多个连续行上有斜杠分隔的整数。
这是我想用来读取和打印所有这些整数的一小段代码:
import java.util.Scanner;
import java.io.File;
class Testing {
public static void main (String[] args) throws Exception {
Scanner file = new Scanner(new File("data.txt"));
file.useDelimiter("/");
while (file.hasNextInt())
System.out.println(file.nextInt());
}
}
数据文件一如下所示:
1/2/3
4/5/6
数据文件一的输出如下所示:
1
2
数据文件二如下所示:
1/2/3
数据文件二的输出如下所示:
1
2
3
有人可以解释为什么我会出现这种行为吗?特别是,为什么第一个示例忽略第一行数据末尾的“3”的存在?
注意:我知道几种“更好”的方法来获得我想要的行为:一次读取整行并使用 split() 和 parseInt(),一次读取整行并将其转换为单独的 Scanner 对象,等等。这不是我的问题。我试图理解为什么这段特定的代码不能按预期工作——特别是,为什么当文件有更多行时我得到的数据更少。
holdtom
有只小跳蛙
30秒到达战场
相关分类