使用JSON序列化与文件IO实现日记持久化,通过BufferedReader/Writer读写文本文件,每篇日记以JSON格式存储并逐行解析;程序启动时加载文件内容反序列化为对象列表,结合Gson库完成数据转换;为提升可读性,设计标题居中、日期右对齐、正文自动换行及分隔线的格式化输出方案,确保信息清晰美观。

开发一个Java个人日记管理程序时,核心需求之一是实现文件持久化和格式化输出。用户希望写下的每一篇日记都能安全保存,并能以清晰、美观的方式查看。本文记录我在实现这两个功能过程中的思路与关键代码。
日记数据的文件持久化
为了让日记在程序关闭后仍能保留,必须将数据写入本地文件。我选择使用Java的BufferedWriter和BufferedReader来操作文本文件,每篇日记独立成行存储,采用JSON格式序列化对象,便于读取和解析。
日记条目类结构如下:
class DiaryEntry {
private String title;
private String content;
private String date;
// 构造方法、getter/setter省略
}
保存日记时,将每个DiaryEntry转换为JSON字符串写入文件:
立即学习“Java免费学习笔记(深入)”;
- 使用
new BufferedWriter(new FileWriter("diaries.txt", true))打开文件并追加内容 - 调用
Gson.toJson(entry)将对象转为JSON字符串(需引入Gson库) - 每次写入后换行,便于逐行读取
从文件加载日记列表
程序启动时需要还原已保存的日记。通过BufferedReader逐行读取文件内容,再用Gson反序列化为DiaryEntry对象。
- 使用
Files.lines(Paths.get("diaries.txt"))流式读取所有行(适用于小文件) - 对每一行执行
gson.fromJson(line, DiaryEntry.class) - 将结果添加到ArrayList中供后续展示
异常处理必不可少:若文件不存在或内容损坏,应提示用户并返回空列表,避免程序崩溃。
格式化输出提升可读性
直接打印JSON内容不利于阅读。为此我设计了美观的控制台输出格式:
- 标题居中显示,用等号包围,如:=== 今日总结 ===
- 日期右对齐,使用
String.format("%40s", date)控制位置 - 正文每行不超过60字符,自动换行,增强阅读体验
- 条目之间插入分隔线(如"────────────────────")区分不同日记
示例输出:
=== 工作复盘 ===2025-04-05
今天完成了项目模块重构,优化了数据加载速度...
───────────────────────────────────────────────
小结
通过结合JSON序列化与文件IO,实现了日记的可靠存储与读取。格式化输出则让信息呈现更友好。后续可扩展支持Markdown渲染或导出HTML功能。基本上就这些,不复杂但容易忽略细节。










