news 2026/5/9 1:55:41

Java------IO (位于 java.io 包中)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java------IO (位于 java.io 包中)

一、概念

1. 流:数据在内存和其他存储设备传输的通道、管道。【理解】

2. 流的分类:【面试内容】

(1) 按照方向分:[以JVM内存为参照物]

a. 输入流:将 [其他存储设备]中数据读入到[JVM内存]中 。->读

b. 输出流:将[JVM内存]中数据写入到[其他存储设备]中。->写

(2) 按照单位分:

a. 字节流:以字节为传输单位,可以用于操作所有类型的文件。

b. 字符流:以字符为传输单位,可以用于操作文本类型的文件。

文本文件:只要能以记事本打开,并且不丢失原有文件内容的文件。

例如: .txt / .java / .c / .html 等

.class / .ppt /.mp3等文件不是文本文件。

(3) 按照功能分:

a. 节点流:只具有基本的读写功能。

b. 过滤流:在节点流的基础上,增强读写功能。

二、字节流

1. 字节流的父类:(父类为抽象类)

(1) InputStream:字节输入流 ---》读操作(read)

(2) OutputStream:字节输出流 --》写操作(write)

2. 字节节点流【开发应用重点】

(1) FileOutputStream:文件字节输出流

常用的构造方法:

a. FileOutputStream fos = new FileOutputStream("E:/test/a.txt");

I. 参数:代表操作文件的路径: "E:/test/a.txt" 或是"E: \ \test \ \ a.txt"

II. 绝对路径:盘符:/ 文件夹 / 文件

III. 注意:如果指定文件不存在,则系统默认创建新的文件,但是如果指定文件夹不存在,则报错,错

误信息为:java.io.FileNotFoundException: (系统找不到指定的路径。)

b. FileOutputStream fos = new FileOutputStream("a.txt");

I. 相对路径:默认在项目的根目录下查找所需要的文件,有直接用,如果指定文件不存在,则系统默

认创建 。

c. FileOutputStream fos = new FileOutputStream("file/c.txt",false);

I. 第一个参数:指定操作文件路径

II. 第二个参数:boolean类型,是否在原有文件内容基础上进行追加,true-追加;false-覆盖

常用方法:

a. void write(int n):将单个字节写入到文件中

b. void write(byte[] bs):将多个字节写入到文件中

c. void write(byte[] bs,int off,int len):将bs数组中的部分内容写入到文件中,起始下标为 off,写入的个

数为len.

d. void close() : 代表关闭资源。

(2) FileInputStream : 文件字节输入流

常用的构造方法:

a. FileInputStream fis = new FileInputStream("file/d.txt");

I. 参数:代表操作文件的路径及文件名,但是如果指定的文件找不到,则系统不会默认创建,直接报

错,错误信息为:java.io.FileNotFoundException: (系统找不到指定的文件。)

常用的方法:

a. int read() : 一次性从文件中读取一个字节的内容,读取的内容作为返回值返回,如果达到文件的尾

部,则返回-1。

开发应用:将文件的内容进行全部读取。

while(true){

int n = fis.read();

if (n==-1) break;

// 基于 n 进行内容操作

System.out.println((char)n);

}

b. int read(byte[] bs):从文件中一次性读取多个字节内容,读取的内容自动存储在bs数组中,返回值

代表实际读取的字节数,如果达到文件的尾部,则返回-1.

c. int read(byte[] bs,int off,int len):从文件中一次性读取多个字节内容,读取的内容自动存储在bs数组

中(存储的起始下标为off),一次性读取的字节个数为 len ,如果达到文件的尾部,则返回-1.

思考:如何实现文件拷贝?---》文件的上传与下载的实现原理。

3. 字节过滤流

(1) BufferedInputStream/ BufferedOutputStream

a. 缓冲流,提高IO读写效率,减少访问磁盘的次数

b. 缓冲流增强了缓冲区,将缓冲的内容一次性写入到文件中,可以调用 flush方法,或是close方法。

flush方法是将缓冲区的内容一次性的写入到文件中,同时缓冲清空,流可以继续使用;

但是close方法是关闭流的同时调用的flush方法,清空缓冲区的同时将缓冲的内容一次性写入文件中,

流不能继续被使用。

注意:当缓冲区满的时候,自动将缓冲区的内容一次性的写入到文件中。

(2) DataOutputStream/DataInputStreama. 用于操作8种基本类型的数据

b. writeByte(形式参数)/ writeShort(参数)/wirteInt(参数)/...

readByte()/readShort()/readInt()/...

(3) ObjectOutputStream/ObjectInputStream

a. 增强了缓冲区

b. 增强了操作8种基本数据类型的功能

c. 增强了操作对象的功能。

writeObject(Object obj):将对象写入到文件中

Object readObject() : 从文件中读取对象。

d. 对象序列化:将对象放在流上进行传输的过程被称为对象序列化。【重点】

I. 对象序列化的要求:参与对象序列化的对象对应的类必须实现java.io.Serializable 接口(标记性接口)

否则运行报错,错误信息为: java.io.NotSerializableException(不可序列化异常) 【重点】

II. 文件达到尾部的标记:java.io.EOFException

III. 被 transient修饰的属性不参与对象序列化 【重点】

Iv. 如果参与对象序列化的对象中有自定义类型的属性,则自定类型的属性对应的类也必须实现

java.io.Serializable接口,否则运行报错,为不可序列化的异常。

V. 集合对应实现了创建的对象可以参与对象序列化,因为实现类实现java.io.Serializable接口;

但是如果集合中存储的是自定义类型的对象,则自顶类型的对象对应 的类也需要实现

java.io.Serializable接口。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/4 20:58:25

Linly-Talker后端服务部署最佳实践(Docker/K8s)

Linly-Talker后端服务部署最佳实践(Docker/K8s) 在直播带货间里,一个数字人正用流畅的中文介绍新款手机,口型与语音严丝合缝;银行APP中,虚拟柜员微笑着回答客户关于利率的问题,声音亲切熟悉——…

作者头像 李华
网站建设 2026/5/1 12:58:36

Linly-Talker评论区互动机器人集成设想

Linly-Talker评论区互动机器人集成设想 在B站、抖音等视频平台的热门内容下,评论区常常成为“第二现场”——用户提问密集、情绪高涨,而创作者却难以一一回应。这种高互动需求与低响应效率之间的矛盾,正是AI数字人技术可以大展身手的场景。 设…

作者头像 李华
网站建设 2026/5/3 4:48:12

Linly-Talker A/B测试框架搭建经验谈

Linly-Talker A/B测试框架搭建经验谈 在虚拟主播、智能客服和在线教育等场景中,数字人正从“炫技演示”走向“真实可用”。然而,一个关键问题始终困扰着开发者:我们换了个更强大的语音合成模型,用户真的觉得更好了吗?响…

作者头像 李华
网站建设 2026/5/3 16:48:59

Docker离线部署svn详细教程

本章教程,主要记录如何离线Docker搭建svn服务器端。适用于内网环境。 一、准备svn离线Docker包 下载地址:https://download.csdn.net/download/qq_19309473/92476310 docker load -i svn-server.tar二、构建命令 创建一个docker-compose.yml文件,写入以下内容。 version: 3 …

作者头像 李华
网站建设 2026/5/3 3:11:39

Linly-Talker批量生成模式上线:适合大规模内容生产

Linly-Talker批量生成模式上线:适合大规模内容生产 在今天的数字内容战场上,效率就是生命线。当一个教育机构需要为新学期准备上百节课程视频,或一家电商平台要在大促前产出数千条商品讲解短视频时,传统依赖人工拍摄与剪辑的方式早…

作者头像 李华
网站建设 2026/5/1 8:14:20

Linly-Talker API文档发布:开发者快速接入指南

Linly-Talker API文档发布:开发者快速接入指南 在虚拟主播24小时不间断带货、AI客服精准回应千人千问的今天,一个真正“能听、会说、有表情”的数字人早已不再是科幻电影中的桥景。但要让一张静态照片变成能实时对话的数字生命体,背后需要跨越…

作者头像 李华