Java学习——day21
文章目录
- 1. 设计说明
- 2.完整代码:
- 3. 代码分析:
- 3.1 引入的包与整体结构
- 3.2 Logger 类分析
- 3.2.1 类的属性
- 3.2.2 构造方法
- 3.2.3 日志记录方法:log()
- 3.2.4 日志查询方法:readLog()
- 3.3 主程序 main() 分析
- 4. 今日生词
今日学习目标:
第 7 天:复习 & 小项目
目标
巩固本周所学的文件 I/O 知识。
完成一个 日志记录系统 项目。
实践任务
日志记录系统:
编写一个 Logger 类,每次程序运行时,记录当前时间和操作日志到 log.txt 文件中。
允许用户查询日志历史记录。
(昨天忘记发了,今早补发一下)
1. 设计说明
-
Logger 类
- 构造方法中调用 log(“程序启动”),每次程序运行时都会记录启动时间。
- log 方法采用 try-with-resources,使用 BufferedWriter 以追加模式写入日志;若发生异常则捕获并输出提示信息。
- readLog 方法读取 log.txt 文件内容并输出到控制台,确保用户可以查询日志历史记录。
-
主程序
- 提供了一个基于命令行的菜单,通过 switch-case 处理不同选项。
- 用户可以输入新的日志信息,程序会调用 Logger 的 log 方法记录日志。
- 查询日志选项调用 readLog() 方法展示历史记录。
- 退出程序前调用 log(“程序退出”) 记录退出操作。
2.完整代码:
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;
public class LogSystem {
// Logger 类封装了日志记录和查询的功能
public static class Logger {
private final String logFileName = "log.txt";
private final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// 构造方法中记录程序启动日志
public Logger() {
log("程序启动");
}
// 记录日志,将时间戳和消息追加到 log.txt 文件中
public void log(String message) {
String timeStamp = sdf.format(new Date());
String logEntry = timeStamp + " - " + message;
try (BufferedWriter writer = new BufferedWriter(new FileWriter(logFileName, true))) {
writer.write(logEntry);
writer.newLine();
} catch (IOException e) {
System.out.println("日志记录失败: " + e.getMessage());
}
}
// 读取日志文件内容并输出到控制台
public void readLog() {
File file = new File(logFileName);
if (!file.exists()) {
System.out.println("日志文件不存在。");
return;
}
System.out.println("----- 日志历史记录 -----");
try (BufferedReader reader = new BufferedReader(new FileReader(file))) {
String line;
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
} catch (IOException e) {
System.out.println("读取日志失败: " + e.getMessage());
}
System.out.println("----- 日志结束 -----");
}
}
// 主程序:提供简单菜单,允许用户记录日志和查询日志历史记录
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
Logger logger = new Logger(); // 程序启动时自动记录日志
boolean exit = false;
while (!exit) {
System.out.println("\n请选择操作:");
System.out.println("1. 记录新的日志");
System.out.println("2. 查询日志历史记录");
System.out.println("3. 退出");
System.out.print("请输入选项(1/2/3): ");
String option = scanner.nextLine();
switch (option) {
case "1":
System.out.print("请输入要记录的日志信息: ");
String logMessage = scanner.nextLine();
logger.log(logMessage);
System.out.println("日志记录成功。");
break;
case "2":
logger.readLog();
break;
case "3":
logger.log("程序退出");
System.out.println("程序结束。");
exit = true;
break;
default:
System.out.println("无效的选项,请重新输入。");
}
}
scanner.close();
}
}
3. 代码分析:
3.1 引入的包与整体结构
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;
- java.io.*:提供文件输入输出相关的类,如
FileReader
、BufferedReader
、FileWriter
、BufferedWriter
等,用于文件的读写操作。 - java.text.SimpleDateFormat:用于格式化日期。这里用于将当前时间格式化为
yyyy-MM-dd HH:mm:ss
的字符串。 - java.util.Date:用于获取当前日期和时间。
- java.util.Scanner:用于从控制台接收用户输入。
整个程序定义在一个类LogSystem
中,其中包含一个内部静态类Logger
和main
方法。
3.2 Logger 类分析
3.2.1 类的属性
public static class Logger {
private final String logFileName = "log.txt";
private final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// ...
}
- logFileName:定义日志文件的名称,所有日志记录都追加写入这个文件中。
- sdf:一个
SimpleDateFormat
实例,用来格式化当前日期时间为固定格式,确保每条日志都有标准的时间戳。
3.2.2 构造方法
public Logger() {
log("程序启动");
}
- 在创建
Logger
对象时,立即记录一条“程序启动”的日志。这可以帮助后续分析程序运行的时间点。
3.2.3 日志记录方法:log()
public void log(String message) {
String timeStamp = sdf.format(new Date());
String logEntry = timeStamp + " - " + message;
try (BufferedWriter writer = new BufferedWriter(new FileWriter(logFileName, true))) {
writer.write(logEntry);
writer.newLine();
} catch (IOException e) {
System.out.println("日志记录失败: " + e.getMessage());
}
}
- 时间戳获取:
sdf.format(new Date())
获取当前时间,并转换为字符串。 - 构造日志条目:将时间戳与用户提供的日志消息拼接,中间用 “ - ” 分隔。
- try-with-resources:使用
BufferedWriter
和FileWriter
以追加模式打开日志文件(第二个参数true
表示追加写入),确保操作完成后自动关闭流。 - 异常处理:捕获
IOException
,如果写入过程中出错,给出友好的错误提示。
3.2.4 日志查询方法:readLog()
public void readLog() {
File file = new File(logFileName);
if (!file.exists()) {
System.out.println("日志文件不存在。");
return;
}
System.out.println("----- 日志历史记录 -----");
try (BufferedReader reader = new BufferedReader(new FileReader(file))) {
String line;
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
} catch (IOException e) {
System.out.println("读取日志失败: " + e.getMessage());
}
System.out.println("----- 日志结束 -----");
}
- 文件检查:首先判断日志文件是否存在,若不存在则提示用户并退出方法。
- 使用 try-with-resources:以自动关闭流的方式读取日志文件内容。
- 逐行读取:使用
BufferedReader
的readLine()
方法读取文件每一行,直至文件末尾。 - 异常捕获:同样处理可能出现的
IOException
,确保程序健壮性。
3.3 主程序 main() 分析
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
Logger logger = new Logger(); // 程序启动时自动记录日志
boolean exit = false;
while (!exit) {
System.out.println("\n请选择操作:");
System.out.println("1. 记录新的日志");
System.out.println("2. 查询日志历史记录");
System.out.println("3. 退出");
System.out.print("请输入选项(1/2/3): ");
String option = scanner.nextLine();
switch (option) {
case "1":
System.out.print("请输入要记录的日志信息: ");
String logMessage = scanner.nextLine();
logger.log(logMessage);
System.out.println("日志记录成功。");
break;
case "2":
logger.readLog();
break;
case "3":
logger.log("程序退出");
System.out.println("程序结束。");
exit = true;
break;
default:
System.out.println("无效的选项,请重新输入。");
}
}
scanner.close();
}
- Scanner 对象:用于读取用户的输入。
- Logger 实例:实例化
Logger
对象时自动记录“程序启动”,确保每次程序运行都有记录。 - 菜单循环:
- 使用
while
循环不断展示菜单,直到用户选择退出。 - 选项 “1”:提示用户输入日志信息,并调用
logger.log()
方法记录该信息。操作完成后反馈“日志记录成功”。 - 选项 “2”:调用
logger.readLog()
方法读取并显示日志历史记录。 - 选项 “3”:在退出前记录一条“程序退出”的日志,然后结束循环。
- 对于其他输入,则提示“无效的选项”。
- 使用
- 关闭资源:退出循环后调用
scanner.close()
关闭输入流,避免资源泄漏。
4. 今日生词
1.instance 2.ingredient 3.domestic 4.appetite 5.journal