登录
首页 >  文章 >  java教程

JavaScanner读取文件全攻略

时间:2026-03-16 17:39:44 377浏览 收藏

本文深入剖析了Java中Scanner读取文件时常见的卡顿、NoSuchElementException异常及中文乱码等痛点问题,直击根本原因——默认分隔符机制、输入流耗尽风险与编码未显式指定,并给出切实可行的解决方案:优先采用hasNextLine()+nextLine()逐行安全读取,警惕nextInt()等方法后残留换行符需额外调用nextLine()清除,且务必在构造Scanner时显式指定StandardCharsets.UTF_8编码;同时点明Scanner因内置词法解析和类型转换而性能远逊于纯字符搬运的BufferedReader,帮助开发者避开陷阱、写出健壮高效的文件读取代码。

Java中如何使用Scanner读取文件内容_Java简易IO操作

Scanner读文件时卡住或抛NoSuchElementException

根本原因不是文件没找到,而是Scanner默认用空格/换行作分隔符,遇到空行、末尾换行或纯空白字符就可能提前耗尽输入流。尤其当用next()nextInt()这类“跳过分隔符”的方法时,hasNext()返回false后还强行调用next(),立刻崩出NoSuchElementException

  • 优先用hasNextLine() + nextLine()逐行读,不依赖内容格式
  • 避免混用nextXXX()nextLine():比如刚调完nextInt(),下一行nextLine()会读到残留的换行符,直接返回空字符串——此时得额外加一次nextLine()“吃掉”它
  • 文件编码必须匹配:中文乱码大概率是没指定Charset,构造Scanner时显式传StandardCharsets.UTF_8

Scanner vs BufferedReader读文件性能差多少

Scanner本质是带词法解析的包装器,每次nextXXX()都要做正则匹配、类型转换、异常捕获;而BufferedReader只是高效搬运字符。小文件(Scanner慢2–5倍很常见。

  • 纯按行处理(如解析配置、日志过滤):直接上BufferedReader,代码更短、更稳
  • 真需要切分字段(如"name,age,city"):先用BufferedReader.readLine()拿整行,再用String.split(",")StringTokenizer——比Scanner.useDelimiter(",")快且可控
  • Scanner唯一优势场景:交互式命令行输入,或格式高度不规则需边读边判断类型

用Scanner读文件必须关流吗

必须。虽然Scannerclose()会级联关闭底层FileInputStream,但漏掉它会导致文件句柄泄露——Windows下文件可能被锁死,Linux下累积太多会触发“Too many open files”错误。

  • 别用finally手动关:容易在catch里重复关或吞异常
  • 一律用try-with-resources:try (Scanner sc = new Scanner(new File("data.txt"), StandardCharsets.UTF_8)) { ... }
  • 注意:如果传入的是System.in,千万别关——关了整个控制台输入就废了

Scanner读取路径含中文或空格的文件失败

不是Scanner的问题,是FilePath构造时没转义。直接拼接"C:\data\测试.txt"在Windows下会因反斜杠被当转义符而路径错乱;空格则让File误判为多个参数。

  • 路径统一用Paths.get("C:/data/测试.txt")new File("C:\\data\\测试.txt")(双反斜杠)
  • 更稳妥:用getClass().getResource("/data/test.txt")从classpath读,避免绝对路径问题
  • 运行时报FileNotFoundException?先用new File("xxx").exists()打个断点确认路径是否真存在
事情说清了就结束。真正麻烦的从来不是语法,是那些没报错却读不到内容、读到一半停住、或者第二天换台机器就乱码的细节。

以上就是《JavaScanner读取文件全攻略》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>