Scanner实现日程管理需统一用nextLine()读输入并手动转换类型,避免换行符问题;用ArrayList存储日程以支持排序与范围查询;退出时用带标签break并关闭Scanner;优先使用线程安全的DateTimeFormatter替代SimpleDateFormat。

怎么用 Scanner 实现日程的增删查改
控制台日程管理器的核心是交互,Scanner 是最直接的选择,但要注意它读取 nextLine() 时容易跳过换行符。比如先调用 nextInt() 再跟 nextLine(),后者会立刻返回空字符串——因为 nextInt() 不消费回车符。
实操建议:
- 统一用
nextLine()读所有输入,再对数字类字段用Integer.parseInt()转换,避免缓冲区混乱 - 日期输入建议用固定格式如
"yyyy-MM-dd",后续可用LocalDate.parse(input)解析(需 try-catch) - 删除操作前务必确认,比如输出待删日程并提示
"确认删除?(y/n)",再用scanner.nextLine().trim().equalsIgnoreCase("y")
用 ArrayList 还是 HashMap 存日程数据
初学者常纠结结构选型。实际场景中,日程需要按时间排序、支持模糊搜索(如“会议”)、还要能快速按 ID 删除——ArrayList 更合适,因为:
-
ArrayList天然保持插入顺序,配合Collections.sort()可按LocalDateTime排序 - 遍历查找成本可控(几十条数据内),用
stream().filter()写搜索逻辑清晰 -
HashMap虽然查 ID 快,但无法天然支持“今天的所有日程”这类范围查询,反而要额外维护索引
示例:按日期筛选今日日程可写成 list.stream().filter(s -> s.getDate().equals(LocalDate.now())).collect(Collectors.toList())
立即学习“Java免费学习笔记(深入)”;
怎么让退出功能真正终止程序而不卡住
常见错误是只写 break 跳出 while 循环,但主方法没结束,控制台还挂着;或者用 System.exit(0) 过于粗暴,没释放资源(虽然本项目无文件/网络连接,但习惯要养)。
更稳妥的做法:
- 用带标签的
break直接跳出主循环,例如:mainLoop: while (true) { ... break mainLoop; } - 如果用了 Scanner,退出前调用
scanner.close(),防止 IDE(如 IntelliJ)警告资源未关闭 - 避免在 switch case 中写
return结束 main 方法——这会让逻辑散落,不易扩展
为什么 SimpleDateFormat 要换成 DateTimeFormatter
很多教程还在用 SimpleDateFormat,但它不是线程安全的,且在 Java 8+ 中已被明确标记为 legacy。控制台程序虽单线程,但用错 API 容易埋坑,比如:
-
SimpleDateFormat的parse()抛ParseException,必须 try-catch;而DateTimeFormatter的parse()抛DateTimeParseException,类型更精准 -
DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm")比new SimpleDateFormat("yyyy-MM-dd HH:mm")更简洁,且默认不可变、线程安全 - 日期比较也更直观:用
LocalDateTime.isAfter(other),不用再转毫秒数比大小
别小看这点——一旦以后加导出 CSV 或对接数据库,用现代时间 API 能省掉大量胶水代码。
真正难的不是实现增删查改,而是把输入校验、异常分支、用户提示这些“不酷”的细节做扎实。比如一个没 trim 的空输入、一个没 catch 的日期解析失败,都会让整个程序在演示时当场卡死。










