Java 扫描器、分隔符和行尾

我有一个数据文件,在多个连续行上有斜杠分隔的整数。

这是我想用来读取和打印所有这些整数的一小段代码:


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 对象,等等。这不是我的问题。我试图理解为什么这段特定的代码不能按预期工作——特别是,为什么当文件有更多行时我得到的数据更少。


慕哥9229398
浏览 124回答 3
3回答

holdtom

最后一个hasNextInt()将读取带有回车符的元素。即该元素将为3\r\n. 这显然不是 int,因此它将无法通过测试file.hasNextInt()

有只小跳蛙

当它到达第 1 行末尾时,即值 3 之后,有一个“返回字符”,它不是整数。从那里开始,您对 hasNextInt() 的测试开始失败。所以它最多只打印 3。即 1 2 3

30秒到达战场

行尾旁边的 1hasNextInt()将返回 false,因为它返回3\r\n,从而导致问题。简单的解决方案可以是 -public static void main (String[] args) throws Exception {      Scanner file = new Scanner(new File("test.txt"));      file.useDelimiter("/");      while (file.hasNext())         System.out.println(file.next());   }输出现在看起来像 -123456
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java