(每日持续更新)jdk api之FileOutputStream基础、应用、实战

发布时间:2024年01月17日

博主18年的互联网软件开发经验,从一名程序员小白逐步成为了一名架构师,我想通过平台将经验分享给大家,因此博主每天会在各个大牛网站点赞量超高的博客等寻找该技术栈的资料结合自己的经验,晚上进行用心精简、整理、总结、定稿,每天都会整理到12点,为了就是能让大家能够真正了解该技术栈的真正原理,最终从程序员成为一名真正的架构师,写的不一定是全站做好的,但是是全站最用心的~。

以后我会推出一些列的文章,每天都会更新,每天进步一点点,发布顺序【java的api基础、应用、实战】->【java开源技术栈及源码分析】->【java开源技术栈整合】->【java低代码开发平台的建设】

一、java.io

1.22 FileOutputStream

FileOutputStream 介绍:

FileOutputStream 是 Java I/O 中用于写入文件的类,它继承自 OutputStream 类。通过 FileOutputStream,可以向文件中写入字节数据。

FileOutputStream 所有字段:

FileOutputStream 类没有公共字段。

FileOutputStream 构造方法:
  • FileOutputStream(File file) 创建一个向指定 File 对象表示的文件中写入数据的文件输出流。

  • FileOutputStream(File file, boolean append) 创建一个向指定 File 对象表示的文件中写入数据的文件输出流,如果 appendtrue,则将数据追加到文件末尾,否则将覆盖文件内容。

  • FileOutputStream(String name) 创建一个向具有指定名称的文件中写入数据的输出文件流。

  • FileOutputStream(String name, boolean append) 创建一个向具有指定名称的文件中写入数据的文件输出流,如果 appendtrue,则将数据追加到文件末尾,否则将覆盖文件内容。

FileOutputStream 方法摘要:

以下是一些常用的 FileOutputStream 方法:

  • void write(int b) 将指定的字节写入文件输出流。

  • void write(byte[] b) 将 b.length 个字节从指定的 byte 数组写入此文件输出流。

  • void write(byte[] b, int off, int len) 将指定 byte 数组中从偏移量 off 开始的 len 个字节写入文件输出流。

  • void close() 关闭此文件输出流并释放与此流相关联的任何系统资源。

  • void flush() 刷新此文件输出流的缓冲区。

简单使用例子:

以下是一个简单的例子,演示如何使用 FileOutputStream 写入数据到文件:

javaCopy code
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
?
public class FileOutputStreamExample {
?
 ?  public static void main(String[] args) {
 ? ? ?  String filePath = "example.txt";
?
 ? ? ?  try (FileOutputStream fos = new FileOutputStream(filePath)) {
 ? ? ? ? ?  // 写入字符串数据
 ? ? ? ? ?  String data = "Hello, FileOutputStream!";
 ? ? ? ? ?  fos.write(data.getBytes());
?
 ? ? ? ? ?  // 写入换行符
 ? ? ? ? ?  fos.write(System.lineSeparator().getBytes());
?
 ? ? ? ? ?  // 写入字节数组
 ? ? ? ? ?  byte[] byteArray = {65, 66, 67, 68, 69}; // ASCII codes for A, B, C, D, E
 ? ? ? ? ?  fos.write(byteArray);
?
 ? ? ? ? ?  System.out.println("Data has been written to the file.");
?
 ? ? ?  } catch (IOException e) {
 ? ? ? ? ?  e.printStackTrace();
 ? ? ?  }
 ?  }
}

在这个例子中,我们创建了一个 FileOutputStream 对象,将字符串和字节数组写入指定的文件(example.txt)。请注意,这里使用了 try-with-resources 语句,确保在写入完成后关闭文件输出流。

应用场景

FileOutputStream 主要用于将数据写入文件。以下是一些常见的应用场景和相应的代码实现:

1. 基本文件写入:
  • 场景: 向文件中写入文本或二进制数据。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.txt")) {
     ?  String data = "Hello, FileOutputStream!";
     ?  fos.write(data.getBytes());
    } catch (IOException e) {
     ?  e.printStackTrace();
    }
2. 文件追加内容:
  • 场景: 将新数据追加到现有文件的末尾。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.txt", true)) {
     ?  String newData = "Appending new data!";
     ?  fos.write(newData.getBytes());
    } catch (IOException e) {
     ?  e.printStackTrace();
    }
3. 写入字节数组:
  • 场景: 将字节数组的内容写入文件。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.bin")) {
     ?  byte[] byteArray = {65, 66, 67, 68, 69}; // ASCII codes for A, B, C, D, E
     ?  fos.write(byteArray);
    } catch (IOException e) {
     ?  e.printStackTrace();
    }
4. 写入部分字节数组:
  • 场景: 从字节数组的特定位置开始写入一部分数据。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.bin")) {
     ?  byte[] byteArray = {65, 66, 67, 68, 69}; // ASCII codes for A, B, C, D, E
     ?  fos.write(byteArray, 1, 3); // Writes B, C, D
    } catch (IOException e) {
     ?  e.printStackTrace();
    }
5. 写入文件时异常处理:
  • 场景: 在写入文件时处理可能的异常。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.txt")) {
     ?  String data = "Hello, FileOutputStream!";
     ?  fos.write(data.getBytes());
    } catch (IOException e) {
     ?  System.err.println("Error writing to the file: " + e.getMessage());
    }
6. 刷新缓冲区:
  • 场景: 在写入文件后手动刷新缓冲区。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.txt")) {
     ?  String data = "Hello, FileOutputStream!";
     ?  fos.write(data.getBytes());
     ?  fos.flush(); // 刷新缓冲区
    } catch (IOException e) {
     ?  e.printStackTrace();
    }
7. 自定义缓冲区大小:
  • 场景: 设置自定义的缓冲区大小以提高写入性能。

  • 代码实现:

    javaCopy code
    try (FileOutputStream fos = new FileOutputStream("output.txt")) {
     ?  String data = "Hello, FileOutputStream!";
     ?  byte[] buffer = data.getBytes();
     ?  fos.write(buffer, 0, buffer.length);
    } catch (IOException e) {
     ?  e.printStackTrace();
    }

这些示例覆盖了一系列使用 FileOutputStream 的常见应用场景。实际使用时,根据具体需求进行适当的调整和组合。

实战例子

让我们考虑一个简单的项目实战例子,假设你正在开发一个日志记录系统,需要将日志信息写入文件。以下是一个使用 FileOutputStream 的基本项目实战例子:

javaCopy code
import java.io.FileOutputStream;
import java.io.IOException;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
?
public class SimpleLogger {
?
 ?  private static final String LOG_FILE = "application.log";
?
 ?  public static void main(String[] args) {
 ? ? ?  // 模拟日志记录
 ? ? ?  log("Application started.");
?
 ? ? ?  // 模拟应用程序运行中的一些操作
 ? ? ?  performSomeOperations();
?
 ? ? ?  // 模拟日志记录
 ? ? ?  log("Application stopped.");
 ?  }
?
 ?  private static void performSomeOperations() {
 ? ? ?  // 模拟应用程序运行中的一些操作
 ? ? ?  log("Performing some operations...");
?
 ? ? ?  // 模拟错误发生
 ? ? ?  logError("Error occurred during operation.");
?
 ? ? ?  // 模拟更多操作...
?
 ? ? ?  log("Operations completed.");
 ?  }
?
 ?  private static void log(String message) {
 ? ? ?  try (FileOutputStream fos = new FileOutputStream(LOG_FILE, true)) {
 ? ? ? ? ?  // 获取当前时间戳
 ? ? ? ? ?  LocalDateTime timestamp = LocalDateTime.now();
 ? ? ? ? ?  // 格式化时间戳
 ? ? ? ? ?  String formattedTimestamp = timestamp.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
 ? ? ? ? ?  // 构造日志信息
 ? ? ? ? ?  String logEntry = "[" + formattedTimestamp + "] " + message + System.lineSeparator();
 ? ? ? ? ?  // 将日志信息写入文件
 ? ? ? ? ?  fos.write(logEntry.getBytes());
 ? ? ?  } catch (IOException e) {
 ? ? ? ? ?  e.printStackTrace();
 ? ? ?  }
 ?  }
?
 ?  private static void logError(String errorMessage) {
 ? ? ?  // 记录错误信息
 ? ? ?  log("[ERROR] " + errorMessage);
 ?  }
}

在这个例子中,我们创建了一个简单的日志记录系统。每次调用 log 方法时,会将带有时间戳的日志信息追加到名为 application.log 的日志文件中。实际项目中,可以根据需求扩展这个简单的例子,添加更多日志级别、配置选项等。请注意,上述示例使用了 try-with-resources 语句,确保在写入完成后关闭文件输出流。

文章来源:https://blog.csdn.net/a89879193/article/details/135640630
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。