用ArrayList+BlogPost类实现内存版CRUD:id用long、时间用LocalDateTime、重写equals/hashCode;updateById需空指针检查;输入统一用nextLine()并解析;文件操作用Files.write确保UTF-8和目录创建。

用 ArrayList + 简单类结构快速搭起CRUD骨架
不需要数据库也能跑通完整流程,适合练手。核心是把每篇博客抽象成 BlogPost 类,用 ArrayList 当内存数据库。
关键点:字段别用 String 堆砌,要封装可读性——比如 id 用 long、createdAt 用 LocalDateTime,否则后期加时间范围查询会卡死。
-
BlogPost必须重写equals()和hashCode(),否则list.remove(post)可能删不掉 - 所有增删改操作后,建议加一句
System.out.println("当前共 " + posts.size() + " 篇文章"),避免误以为没生效 - ID 不要手动输,用
AtomicLong或静态变量自增,防止重复
public class BlogPost {
private long id;
private String title;
private String content;
private LocalDateTime createdAt;
public BlogPost(long id, String title, String content) {
this.id = id;
this.title = title;
this.content = content;
this.createdAt = LocalDateTime.now();
}
// getter/setter 省略,但必须有
}
实现 updateById() 时最容易漏掉的空指针检查
用户输入 ID 查不到对应文章,直接调 post.setTitle(newTitle) 就抛 NullPointerException。这不是逻辑错,是防御缺失。
真实场景里,ID 输入错误、前端传参丢失、URL 路径参数被截断都可能导致 findPostById() 返回 null。
立即学习“Java免费学习笔记(深入)”;
- 查不到就立刻返回
false或抛自定义异常(如PostNotFoundException),不要继续执行 - 别在 service 层用
System.exit(1)或打印堆栈后沉默——这会让调用方无法区分“没找到”和“系统崩了” - 如果用
Optional,注意optional.orElse(null)又绕回空指针,要用optional.ifPresent(...)
控制台交互别硬写 Scanner.nextLine() 套娃
用户输完标题按回车,再输内容时 nextLine() 经常读到空字符串——因为前一个 nextInt() 或 next() 没吃掉换行符。
统一用 nextLine(),对数字字段再解析:
- 读 ID:用
Integer.parseInt(scanner.nextLine().trim()),并包try-catch NumberFormatException - 读内容:允许空行,但
content.trim().isEmpty()要提示“内容不能为空” - 菜单选择用字符串匹配(如
"1".equals(choice)),别用switch (choice),避免输入字母崩掉
导出为 JSON 或文本文件时路径和编码不能默认
直接写 new FileWriter("posts.txt") 在 Windows 上可能乱码,IDE 运行和 jar 包运行路径也不同。
- 写文件用
Files.write(Paths.get("data/posts.json"), jsonBytes, StandardCharsets.UTF_8) - 先建目录:
Files.createDirectories(Paths.get("data")),否则 Linux/macOS 下直接报No such file or directory - JSON 不用手搓,至少用
Gson库:new Gson().toJson(posts, List.class),别拼字符串
复杂点在于:纯内存版没有事务,导出中途崩溃会导致文件损坏;真要可靠,得加临时文件 + 原子重命名,但小项目先跳过。










