Java单例模式实现日志记录器

1 下载量 128 浏览量 更新于2024-08-03 收藏 2KB TXT 举报
"该资源提供了一个使用Java单例模式实现的日志记录器示例,名为Logger。这个类确保在整个应用程序中只有一个Logger实例,并且能够安全地写入日志到指定的文件路径。" 在Java编程中,单例模式是一种常用的创建型设计模式,它的主要目的是保证一个类只有一个实例,并提供一个全局访问点。在提供的代码中,Logger类实现了单例模式,以控制日志记录器的实例化过程。 首先,`Logger` 类的构造方法被声明为私有的(`private`),这样外部就不能直接通过 `new Logger()` 来创建实例。取而代之的是,类内部定义了一个静态变量 `instance`,用于存储单个Logger实例。此外,为了保证多线程环境下的安全性,还定义了一个静态的 `final Object lock` 作为同步锁。 `getInstance()` 方法是获取Logger实例的关键。它是一个静态方法,意味着可以通过类名直接调用,无需实例化对象。在这个方法中,使用了 `synchronized` 关键字来确保同一时间只有一个线程可以执行这个方法。方法内首先检查 `instance` 是否为 `null`,如果为 `null`,则创建新的 `Logger` 实例并赋值给 `instance`。这种实现方式被称为"双重检查锁定"(Double-Check Locking)模式,既保证了单例,又减少了不必要的同步开销。 `writeLog()` 方法是用于写入日志的实际操作。它接受一个字符串 `message` 作为参数,然后使用 `BufferedWriter` 和 `FileWriter` 将消息写入到指定的 `logFilePath` 文件中。为了处理可能的IO异常,使用了try-catch语句来捕获并打印异常堆栈信息。 这个简单的日志记录器例子展示了如何在Java中应用单例模式,以及如何利用文件I/O进行日志记录。在实际项目中,日志记录器通常会更复杂,包括日志级别管理、日志格式化、日志滚动等功能,但这个基础示例提供了理解单例模式和基本日志写入的起点。开发者可以根据需求进一步扩展这个类,例如添加日志级别支持、使用日志框架如Log4j或slf4j等。