数字字典应用是检验Scanner、HashMap、异常处理和基础IO掌握程度的分水岭;须用HashMap存词条,注意大小写、空值处理、nextLine()吃回车问题,文件读写需UTF-8编码与健壮异常处理。

数字字典应用不是“练手玩具”,而是检验你是否真正理解 Scanner、HashMap、异常处理和基础 IO 的分水岭——写完能查、能存、能改,才算 Java 控制台程序入门过关。
用 HashMap 存词条,别碰数组或 List
初学者常想用 ArrayList 存“单词-释义”对,结果遍历查词慢、删词错位、重复词难处理。而 HashMap 天然适合键值映射,查词是 O(1),且自动去重(同单词再次 put 就覆盖)。
注意点:
-
HashMap的键区分大小写,"Java"和"java"是两个键;如需忽略大小写,统一转成toLowerCase()再存取 - 不要用
new HashMap()后直接get(),必须先判空:if (dict.containsKey(word)) { ... } - 避免用
null作键或值;若释义为空,存""而非null,否则get()返回null无法区分“没这个词”还是“这个词释义为空”
从 Scanner 读用户输入时,小心 nextLine() 被吃掉
菜单选择用 nextInt() 后,紧接着调 nextLine() 读单词,会立刻返回空字符串——因为 nextInt() 不吞回车,残留的换行符被下一个 nextLine() 直接读走。
立即学习“Java免费学习笔记(深入)”;
正确做法:
- 统一用
nextLine()读所有输入,再用Integer.parseInt()转数字选项 - 如果坚持混用,
nextInt()后加一句scanner.nextLine();清掉换行符 - 输入单词前,先
trim()去首尾空格:word = scanner.nextLine().trim();,否则"hello "和"hello"查不到同一个释义
保存到文件用 PrintWriter,别用 FileWriter 直接写
FileWriter 写中文容易乱码,且不提供 println() 这类便利方法;而 PrintWriter 可指定编码、自动换行、容错更强。
关键配置:
- 构造时传
new OutputStreamWriter(new FileOutputStream("dict.txt"), "UTF-8"),硬编码 UTF-8 避免 Windows 默认 GBK 导致乱码 - 每次写一对词条,用
pw.println(word + "\t" + meaning);,用制表符\t分隔,比空格/逗号更可靠(释义里可能含空格或逗号) - 写完必须调
pw.close(),否则缓冲区内容不落地;建议用 try-with-resources 自动关闭
try (PrintWriter pw = new PrintWriter(
new OutputStreamWriter(
new FileOutputStream("dict.txt"), "UTF-8"))) {
for (Map.Entry entry : dict.entrySet()) {
pw.println(entry.getKey() + "\t" + entry.getValue());
}
}
启动时从文件加载,要处理 FileNotFoundException 和格式错误
第一次运行时 dict.txt 不存在,不能让程序崩溃;文件存在但某行少一个 \t,也不能因 split("\t")[1] 报 ArrayIndexOutOfBoundsException 而退出。
健壮加载逻辑:
- 用
try-catch(FileNotFoundException)捕获,捕获后直接用空HashMap,不打印堆栈 - 每行用
line.split("\t", 2)(限制最多切 2 份),再检查长度是否为 2;不足就跳过该行,打一句System.err.println("跳过格式错误行: " + line); - 读出的 key/value 仍要
trim(),防止文件里有隐藏空格影响后续查询
真正的难点不在功能实现,而在边界:空输入、文件缺失、编码混乱、磁盘满、键含制表符……这些地方不加防护,程序在自己电脑跑通,换台机器就崩。写完先故意删掉 txt 文件、输一堆空格、存个带 \t 的单词,看看它还稳不稳。










