「解析文件流,Java之FileOutputStream助您轻松操作文件!」

在这里插入图片描述


🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!!

环境说明:Windows 10 + IntelliJ IDEA 2021.3.2 + Jdk 1.8

文章目录

  • 前言
  • 摘要
  • FileOutputStream
    • 1. Java IO包基础
    • 2. FileOutputStream类介绍
      • 2.1 创建FileOutputStream对象
      • 2.2 写入数据
      • 2.3 关闭FileOutputStream
    • 3. 常用方法
    • 应用场景
    • 优缺点分析
      • 优点:
      • 缺点:
    • 4. 示例代码
    • 5. 测试用例
      • 5.1 用例代码
      • 5.2 代码解析
      • 5.3 测试结果
    • 6. 源码分析
      • 6.1 构造函数
      • 6.2 write() 方法
      • 6.3 其他方法
      • 6.4 源码截图
    • 全文小结
  • 总结
    • 附录源码
  • ☀️建议/推荐你
  • 📣关于我

  咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java之IO流啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~

在这里插入图片描述

前言

  Java是一门广泛应用于开发各种应用程序的编程语言,也广泛应用于文件操作方面,其中FileOutputStream是Java IO包中常用的类之一。本文将介绍如何使用FileOutputStream类来操作文件流,以方便开发人员更加轻松地读写文件。

摘要

  本文主要介绍了Java中文件操作的基本知识和FileOutputStream类的使用方法。在介绍FileOutputStream类之前,我们先了解了Java IO包中的一些基本的类,比如InputStream、OutputStream、File、FileReader等等。在具体的介绍中,我们详细讲解了如何使用FileOutputStream来写入文件,并给出了相应的示例代码。最后,我们还介绍了一些FileOutputStream类的常用方法。

FileOutputStream

1. Java IO包基础

  Java IO包是Java编程语言中用于读写数据的API。它提供了一个非常简单和易于使用的接口,以帮助我们轻松地读写文件。在Java IO包中,常用的类有InputStreamOutputStreamReaderWriter,它们都是抽象类。另外,Java IO包中还包含了一些具体的类,如File、FileInputStream、FileOutputStream等。

2. FileOutputStream类介绍

  FileOutputStream类是Java IO包中用于写入文件的类。通过FileOutputStream类,我们可以将数据写入到文件中。

2.1 创建FileOutputStream对象

FileOutputStream fos = new FileOutputStream("example.txt");

2.2 写入数据

String data = "Hello, world!";
byte[] bytes = data.getBytes();
fos.write(bytes);

2.3 关闭FileOutputStream

写入完成后,需要关闭FileOutputStream,以释放资源。

fos.close();

3. 常用方法

常用的方法有:

  • write(byte[] b): 将字节数组写入数据流。
  • write(byte[] b, int off, int len): 将字节数组中的一部分写入数据流。
  • flush(): 刷新数据流。
  • close(): 关闭输出流。

应用场景

  FileOutputStream是Java IO库中的一个类,它用于写入二进制数据到文件中。以下是FileOutputStream的应用场景分析:

  1. 文件写入:FileOutputStream被广泛用于将数据写入文件,特别是在需要将二进制数据写入文件中时。
  2. 网络传输:FileOutputStream也可以用来将二进制数据写入网络流中传输,一些常见的网络编程框架使用FileOutputStream来实现数据的写入。
  3. 数据库存储:将二进制数据写入数据库中也是FileOutputStream的应用之一。

优缺点分析

优点:

  1. 速度快:FileOutputStream是Java IO库中最快的输出流之一,因为它不会像BufferedOutputStream一样缓存数据,直接写入。
  2. 支持二进制数据:FileOutputStream可以写入任何类型的数据,包括二进制数据。
  3. 灵活性高:FileOutputStream可以通过多种方式进行数据写入,例如:按字节写入、按字符写入等。

缺点:

  1. 不支持缓存:FileOutputStream不支持数据缓存,这意味着每次写入操作都需要打开文件并写入数据,增加了文件I/O的开销。
  2. 不能在文件中追加数据:FileOutputStream只会覆盖文件中原有的数据,不能在文件最后面追加数据。
  3. 不支持高级的字符处理:FileOutputStream只能处理字节数据而不能处理字符数据,必须通过其他类如OutputStreamWriter进行处理。

  综上所述,FileOutputStream是Java IO库中功能强大的输出流之一,可用于高效地将二进制数据写入文件、网络流或数据库中。但是,它不支持缓存和追加数据等高级功能。因此,在选择输出流时要权衡其优势和劣势。

4. 示例代码

下面是一个示例代码,展示了如何使用FileOutputStream将数据写入文件中。

import java.io.FileOutputStream;
import java.io.IOException;public class FileWriterExample {public static void main(String[] args) throws IOException {FileOutputStream fos = new FileOutputStream("example.txt");String data = "Hello, world!";byte[] bytes = data.getBytes();fos.write(bytes);fos.close();}
}

测试运行结果如下:

在这里插入图片描述

5. 测试用例

5.1 用例代码

  我们可以编写一些测试用例来确保代码的正确性。下面是一个简单的测试用例,展示了如何验证代码是否按预期工作。

package com.example.javase.io.fileOutputStream;import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;/*** @Author bug菌* @Date 2023-10-15 19:40*/
public class FileOutputStreamTest {public static void main(String[] args) throws IOException {String data = "Hello, world,jym!";File file = new File("./template/hello.txt");FileOutputStream fos = new FileOutputStream(file);fos.write(data.getBytes());fos.close();FileInputStream fis = new FileInputStream(file);byte[] buffer = new byte[1024];fis.read(buffer);String result = new String(buffer).trim();fis.close();if (data.equals(result)) {System.out.println("Pass");} else {System.out.println("Fail");}}
}

5.2 代码解析

  该代码演示了如何使用Java的FileOutputStream类来写文件以及使用FileInputStream类来读文件。首先创建了一个字符串数据,然后使用FileOutputStream将其写入到文件中。写入完成后,使用FileInputStream读取文件中的内容,并将读取结果与原始数据进行比较,以确认写入和读取都成功。最后,根据比较结果输出相应的信息(Pass 或 Fail)。

5.3 测试结果

如上测试用例测试结果如下:

在这里插入图片描述

6. 源码分析

  FileOutputStream 是一个 Java IO 中的输出流类,用于将数据写入到文件中。下面是它的源码分析:

6.1 构造函数

public FileOutputStream(String name) throws FileNotFoundException {this(name != null ? new File(name) : null, false);
}public FileOutputStream(String name, boolean append) throws FileNotFoundException {this(name != null ? new File(name) : null, append);
}public FileOutputStream(File file) throws FileNotFoundException {this(file, false);
}public FileOutputStream(File file, boolean append) throws FileNotFoundException {String name = (file != null ? file.getPath() : null);SecurityManager security = System.getSecurityManager();if (security != null) {security.checkWrite(name);}if (name == null) {throw new NullPointerException();}if (file.isInvalid()) {throw new FileNotFoundException("Invalid file path");}this.fd = new FileDescriptor();this.append = append;open(name, append);
}

  该类提供了多个构造函数,用户可以根据需要选择。其中,最重要的是最后一个构造函数,它接受一个 File 对象和一个 boolean 值,用于指定是否以追加模式打开文件。在构造函数中,会根据传入的文件路径进行权限检查,然后打开文件,并将文件描述符保存在一个 FileDescriptor 对象中。

6.2 write() 方法

public void write(int b) throws IOException {write(new byte[] {(byte) b}, 0, 1);
}public void write(byte b[]) throws IOException {write(b, 0, b.length);
}public void write(byte b[], int off, int len) throws IOException {if (b == null) {throw new NullPointerException();} else if (off < 0 || len < 0 || off > b.length - len) {throw new IndexOutOfBoundsException();} else if (len == 0) {return;}Object traceContext = IoTrace.fileWriteBegin(path);int written = 0;try {ensureOpen();while (written < len) {int bytesToWrite = Math.min(len - written, MAX_BUFFER_SIZE);fd.sync(); // not required for O_APPENDint bytesWritten = writeBytes(b, off + written, bytesToWrite);written += bytesWritten;if (bytesWritten != bytesToWrite) {// If we didn't write what we wanted (and we're not closed), we should// throw an IOException.  But we should not throw it if we're closed.// This is consistent with the behavior of SocketOutputStream.if (written < len) {throw new IOException("File system full");}break;}}if (shouldCloseFD) {// we will no longer be writing to this FileOutputStream, so we should// release our hold on the underlying fd.  This is not strictly necessary,// but it's good citizenship.  :-)close();}} catch (IOException ioe) {IoTrace.fileWriteEnd(traceContext, written);throw ioe;}IoTrace.fileWriteEnd(traceContext, written);
}

  在 write() 方法中,会先进行参数检查,然后调用 ensureOpen()方法确保文件已经打开,接着使用一个循环来写入数据。其中,MAX_BUFFER_SIZE 的值为 8192,即一次最多写入 8KB 的数据。每轮循环会先调用 fd.sync() 方法将缓冲区的数据刷新到磁盘,再调用 writeBytes() 方法将数据写入文件中。在写入数据时,如果写入的字节数小于要写入的字节数,说明文件系统已经满了,此时会抛出一个 IOException 异常。

6.3 其他方法

  FileOutputStream 还提供了一些其他的方法,比如 getFD() 方法可以获取文件描述符,close() 方法可以关闭输出流,flush()方法可以将缓冲区的数据写入磁盘等。这些方法的实现比较简单,就不一一列举了。

6.4 源码截图

  如下是FileOutputStream类在io包中的目录位置及部分源码展示:

在这里插入图片描述

  总的来说,FileOutputStream 的源码比较简单,主要是在写入数据时需要进行一些缓冲区的操作和异常的处理。如果你需要写入文件,那么使用 FileOutputStream 是一个不错的选择。

全文小结

  本文介绍了Java IO包中的一些基本知识和FileOutputStream类的使用方法。在具体的介绍中,我们详细讲解了如何使用FileOutputStream来写入文件,并给出了相应的示例代码。最后,我们也介绍了一些FileOutputStream类的常用方法。通过本文的学习,我们可以更加轻松地操作文件流。

总结

  Java IO包中的FileOutputStream类为开发人员提供了一种非常便捷的写入文件的方式。通过本文对FileOutputStream类的介绍,我们可以更加灵活地使用Java编程语言进行文件的操作。因此,在日常的Java开发中,我们应该熟练掌握FileOutputStream类的使用方法。

  …
  好啦,这期的内容就基本接近尾声啦,若你想学习更多,可以参考这篇专栏总结《「滚雪球学Java」教程导航帖》,本专栏致力打造最硬核 Java 零基础系列学习内容,🚀打造全网精品硬核专栏,带你直线超车;欢迎大家订阅持续学习。

附录源码

  如上涉及所有源码均已上传同步在「Gitee」,提供给同学们一对一参考学习,辅助你更迅速的掌握。

☀️建议/推荐你


  无论你是计算机专业的学生,还是对编程有兴趣的小伙伴,都建议直接毫无顾忌的学习此专栏「滚雪球学Java」,bug菌郑重承诺,凡是学习此专栏的同学,均能获取到所需的知识和技能,全网最快速入门Java编程,就像滚雪球一样,越滚越大,指数级提升。

  最后,如果这篇文章对你有所帮助,帮忙给作者来个一键三连,关注、点赞、收藏,您的支持就是我坚持写作最大的动力。

  同时欢迎大家关注公众号:「猿圈奇妙屋」 ,以便学习更多同类型的技术文章,免费白嫖最新BAT互联网公司面试题、4000G pdf电子书籍、简历模板、技术文章Markdown文档等海量资料。

📣关于我

  我是bug菌,CSDN | 掘金 | infoQ | 51CTO 等社区博客专家,历届博客之星Top30,掘金年度人气作者Top40,51CTO年度博主Top12,华为云 | 阿里云| 腾讯云等社区优质创作者,全网粉丝合计15w+ ;硬核微信公众号「猿圈奇妙屋」,欢迎你的加入!免费白嫖最新BAT互联网公司面试题、4000G pdf电子书籍、简历模板等海量资料。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/730511.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TCP重传机制、滑动窗口、拥塞控制

一、总述 TCP&#xff0c;Transmission Control Protocol&#xff0c;是一个面向连接、基于流式传输的可靠传输协议&#xff0c;考虑到的内容很多&#xff0c;比如数据包的丢失、损坏、分片和乱序等&#xff0c;TCP协议通过多种不同的机制来实现可靠传输。今天&#xff0c;重点…

复试人工智能前沿概念总结

1.大模型相关概念&#xff08;了解即可&#xff09; 1.1 GPT GPT&#xff0c;全称为Generative Pre-training Transformer&#xff0c;是OpenAI开发的一种基于Transformer的大规模自然语言生成模型。GPT模型采用了自监督学习的方式&#xff0c;首先在大量的无标签文本数据上进…

Android使用WebView打开内嵌H5网页

Android打开外部网页链接请参考上一篇文章 https://public.blog.csdn.net/article/details/136384559 继上篇&#xff0c;新建assets文章夹&#xff0c;将H5的网页资源放到此文件夹下 把H5的资源文件都拷进来 这个时候&#xff0c;将添加打开本地网页的代码&#xff1a; //打…

【活动】2024年AI辅助研发:深度变革与无限潜力

作为一名前端程序员&#xff0c;深入探讨2024年AI在软件研发领域的应用趋势及其影响&#xff0c;我们可以看到一场引人注目的转型正在发生。AI辅助研发对于前端开发而言&#xff0c;不仅意味着效率的飞跃&#xff0c;更是在用户体验设计、代码编写、性能优化、项目管理等诸多方…

Java零基础 - 数组的定义和声明

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…

httprunner用例结构(前后置)

说明&#xff1a;httprunner 结合 pytest 的前后置方式 1. 用例级别前后置 1.1. setup teardown class TestCaseRefTestcase(HttpRunner):# 用例级别前后置def setup(self):logger.warning("------用例级别前置")def teardown(self):logger.warning("------用…

在Vue中处理接口返回的二进制图片数据

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

Android使用WebView打开外部网页链接

发布Android应用&#xff0c;除了用原生开发外&#xff0c;更多是采用内嵌H5网页的方式来做&#xff0c;便于更新以及多平台使用。 一、第一种方式是直接通过WebView打开外部H5链接。 新建Android工程 直接创建一个工程&#xff0c;点击运行就可以了&#xff0c;打开是个空页…

2024 批量下载公众号文章内容/阅读数/在看数/点赞数/留言数/粉丝数导出pdf文章备份(带留言):公众号记忆承载近1500篇历史文章在线查看,找文章方便了

关于公众号文章批量下载&#xff0c;我之前写过很多文章&#xff1a; 视频更新版&#xff1a;批量下载公众号文章内容/话题/图片/封面/音频/视频&#xff0c;导出html&#xff0c;pdf&#xff0c;excel包含阅读数/点赞数/留言数 2021陶博士2006/caoz的梦呓/刘备我祖/六神读金…

打造禹州中医药大模型,以AI驱动业务创新(内附孙思邈GPT内测版)

大禹智库 第78 期&#xff08;总第409 期&#xff09; 2024年 3 月 4 日 在中医药传承与发展的关键时期&#xff0c;结合许昌市的地域特色和产业优势&#xff0c;大禹智库提出“打造禹州中医药大模型&#xff0c;以AI驱动业务创新”的战略构想。本报告围绕构建禹州中医药现代化…

旅游陪同翻译,英译中需要具备什么能力!

随着中国旅游业的蓬勃发展&#xff0c;越来越多的外国游客选择踏足这片充满魅力的土地。然而&#xff0c;语言障碍常常成为他们探索中国文化的绊脚石。在这时&#xff0c;旅游陪同翻译应运而生&#xff0c;为游客提供了便捷的语言沟通服务&#xff0c;让他们的旅程更加顺畅和愉…

河北省国际光伏展览会

能源是国民经济发展的重要基础之一。随着国民经济的发展&#xff0c;能源的缺口增大&#xff0c;能源安全及能源在国民经济中的地位越显突出。我国是世界上少数几个能源结构以煤为INVITATION主的国家之一&#xff0c;也是世界上最大的煤炭消费国&#xff0c;燃煤造成的环境污染…

云轴科技ZStack荣获证券基金行业信息技术应用创新联盟年度优秀成员奖

近日&#xff0c;由中国证监会科技监管司、上海市经济和信息化委员会及上交所理事会科技发展委员会指导&#xff0c;证券基金行业信息技术应用创新联盟&#xff08;简称信创联盟&#xff09;主办的2023年年度工作会议在上海成功举办。会议汇聚了来自监管机构、政府机构、行业侧…

Spring Cloud Gateway自定义断言

问题&#xff1a;Spring Cloud Gateway自带的断言&#xff08;Predicate&#xff09;不满足业务怎么办&#xff1f;可以自定义断言&#xff01; 先看Spring Cloud Gateway是如何实现断言的 Gateway中断言的整体架构如下&#xff1a; public abstract class AbstractRoutePred…

【kerberos】hadoop集群使用keytab认证的逻辑

一、背景&#xff1a; haoop的kerberos认证核心是org.apache.hadoop.security.UserGroupInformation类。 UserGroupInformation一般有两种&#xff1a;&#xff08;1&#xff09;apache原生的&#xff08;2&#xff09;cdh hdp改良过的&#xff0c;即cloudera改良过的。 由此衍…

Flink并行度

1、Task flink中每个算子就是一个Task&#xff0c;比如flatMap、map、sum是一个Task。 2、SubTask 算子有几个并行度SubTask的数量就是几&#xff0c;比如 3、算子并行度 算子并行度指的是每个算子的并行度&#xff0c;可用env.setParallelism(1);设置所有算子的并行度&am…

基于Jupyter快速入门Python,Numpy,Scipy,Matplotlib

文章目录 Jupyter 和 Colab 笔记本PythonPython 版本基础数据类型数字Numbers布尔值Booleans字符串Strings 容器列表List字典Dictionaries集合Sets元组Tuples 函数类 Numpy数组Array数组索引Array indexing数据类型DatatypesArray math广播Broadcasting Scipy图像操作MATLAB文件…

goby的安装和使用

简介 Goby是一款基于网络空间测绘技术的新一代网络安全工具&#xff0c;它通过给目标网络建立完整的资产知识库&#xff0c;进行网络安全事件应急与漏洞应急。 Goby可提供最全面的资产识别&#xff0c;目前预置了超过10万种规则识别引擎&#xff0c;能够针对硬件设备和软件业…

一键查看:大厂网站都用了啥技术栈,有图有真相。

本次我们采用Wappalyzer插件来看下国内大厂的网站都采用了什么技术架构&#xff0c;文章最后由Wappalyzer的安装方法。 今日头条网站 淘宝网站 哔哩哔哩 京东商城 花瓣网 CSDN 国务院 网易 58同城 腾讯网 如何安装Wappalyzer 用Edge浏览器即可