使用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字符串写入文件:
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)
异常处理必不可少:若文件不存在或内容损坏,应提示用户并返回空列表,避免程序崩溃。
直接打印JSON内容不利于阅读。为此我设计了美观的控制台输出格式:
String.format("%40s", date)控制位置示例输出:
=== 工作复盘 ===通过结合JSON序列化与文件IO,实现了日记的可靠存储与读取。格式化输出则让信息呈现更友好。后续可扩展支持Markdown渲染或导出HTML功能。基本上就这些,不复杂但容易忽略细节。