OutputStreamWriter
是 Java 中用于将字符数据转换为字节流的类,它可以与 FileOutputStream
结合使用来实现日志文件的记录。以下是一个简单的示例:
import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStreamWriter; import java.nio.charset.StandardCharsets; import java.util.Date; public class LogWriter { private static final String LOG_FILE = "log.txt"; public static void main(String[] args) { try { writeLog("This is a log message."); } catch (IOException e) { System.err.println("Error writing log: " + e.getMessage()); } } public static void writeLog(String message) throws IOException { try (FileOutputStream fos = new FileOutputStream(LOG_FILE, true); OutputStreamWriter osw = new OutputStreamWriter(fos, StandardCharsets.UTF_8)) { String logEntry = new Date() + ": " + message + System.lineSeparator(); osw.write(logEntry); } } }
在这个示例中,我们创建了一个名为 LogWriter
的类,其中包含一个名为 writeLog
的静态方法。这个方法接受一个字符串参数 message
,表示要写入日志文件的消息。我们使用 try-with-resources
语句创建 FileOutputStream
和 OutputStreamWriter
对象,这样可以确保在操作完成后自动关闭它们。
FileOutputStream
的构造函数接受一个布尔值参数 true
,表示我们希望以追加模式打开文件,这样新的日志条目不会覆盖旧的条目。OutputStreamWriter
的构造函数接受一个字符集参数,我们在这里使用 StandardCharsets.UTF_8
以确保正确处理 Unicode 字符。
在 writeLog
方法中,我们首先创建一个包含当前时间和日志消息的字符串 logEntry
,然后使用 OutputStreamWriter
的 write
方法将其写入文件。注意,我们还添加了一个系统相关的行分隔符,以确保在不同操作系统上都能正确地分隔日志条目。
在 main
方法中,我们调用 writeLog
方法来记录一条日志消息。如果在写入过程中发生错误,我们将捕获 IOException
并在控制台上显示错误消息。