Java文件流大家族(通俗易懂,学习推荐版,很详细)——操作文件本身和文件中的数据

本文主要是介绍Java文件流大家族(通俗易懂,学习推荐版,很详细)——操作文件本身和文件中的数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.File(操作文件本身)

1.定义

image-20231206180653780

目录

image-20231206183929227

2.常用方法

image-20231206181806206

image-20231206214434174

image-20231206182029380

image-20231206183832594

image-20231206184430632


3.路径引用符

可以用/或者\\分隔路径

image-20231206181001993

还可以用File.separator分隔路径,会根据不同系统使用啥分隔符。

image-20231206181104660


4.绝对路径、相对路径及桌面路径表示

桌面路径为:

image-20231206183221825

我电脑的用户名为X

image-20231206183230914

image-20231206181951426

5.示例代码(遍历文件夹)

1.创建文件对象

image-20231206181806206

示例:

image-20231206180909537

image-20231206181503808

f1.length():以字节为单位,仅仅是获取该文件夹/文件的大小,如果是文件夹 不是获取文件夹的大小及文件夹里面文件夹的大小之和。

image-20231206181707669

2.常用方法1:判断文件类型(文件、文件夹),获取文件信息等

image-20231206182029380

示例:

image-20231206182202524

image-20231206215044266

image-20231206182256042

image-20231206182346136

如果该文件对象是绝对路径的话,则getAbsolutePath就是绝对路径,若是相对路径则会补全为绝对路径(路径都是带后缀的)

image-20231206182434233

3.常用方法2:创建和删除文件、文件夹

image-20231206183832594

示例:

image-20231206183803260

4.常用方法3:遍历文件夹

image-20231206184430632

示例:

list()列表的名称及包括文件夹名称也包括文件名称(如图中的授课新得.txt)

image-20231206184137871

listFiles()方法能获取当前文件对象路径的一级文件对象,注意是一级文件对象

image-20231206184408806

listFiles()使用注意事项

image-20231206185235358

示例:

1.当主调是文件,返回null

image-20231206185342772

无需ab.txt存不存在,只要是获取文件的一级目录对象都返回null。

路径不存在的一级目录文件对象返回null

image-20231206185501136

2.当主调是空文件夹是,返回一个长度为0的数组,数组内容为[]。图中aaa是空文件夹

image-20231206185119284

3.当主调是一个有内容的文件夹时,将里面所有的一级文件及文件夹的路径放在File数组中返回(即正常情况)

image-20231206184408806

4.这里只演示第一点

image-20231206190054808

image-20231206190310161

test是桌面上的一个文件夹。现在现在这个文件夹和文件进行隐藏。

可以看到隐藏结果获取到了

image-20231206190451789

6.重命名文件、文件夹(renameTo(文件对象)

案例:改变某个文件夹下的视频序号,要求从19开始

image-20231206191104223

image-20231206190938422

image-20231206215917155

直接输出文件对象,会直接输出该文件对象对应的路径

7.文件搜索(递归实现)

image-20231206191659718

image-20231206191958743

image-20231206191947188

再找到像要的文件(对象)后如果要打开或执行,可以用以下代码实现

 Runtime runtime = Runtime.getRuntime();runtime.exec(文件对象.getAbsolutePath());

8.删除非空文件夹(删除文件和删除空文件用相应的方法,可以直接调用)

此密码文件夹假如非空,也就是里面有文件或文件夹

image-20231206192815876

image-20231206192802045

2.IO流(操作文件的数据)

注意:流使用完之后必须用.close()方法关闭

1.概述

image-20231206180729243

image-20231207123441202

2.分类

image-20231207123600843

image-20231207123710407

3.文件流体系结构(基础原始流)

image-20231207123832181

1.FileInputStream(字节输入流)

常用于拷贝文件,文件传输等操作。

image-20231207124135599

1.每次读一个字节(性能差)

1.单个读取文件内容(每次读一个字节,性能能差,而且因为每次读一个字节读汉字会乱码)

image-20231207124325351

2.循环读取文件内容(每次读一个字节,性能能差,而且因为每次读一个字节读汉字会乱码

image-20231207124651500

下面进行改善

2.每次读多个字节(推荐)

自定义字节数组byte [] buffer = new byte[每次读取的字节大小]

image-20231207125449453

bug

image-20231207125945336

最终优化后的代码:

性能得到了明显提升,但是还是不能避免读取汉字时会乱码,如下图每次截取3个字节,可能会把汉字中的字节截断

image-20231207130239779

常用于拷贝文件,文件传输等操作。

3.一次读取完全部字节(可以解决读取的内容中文乱码问题)——不适合一次性读取大文件

image-20231207130706353

image-20231207131454802

方式1

image-20231207131520767

用完记得用close()方法关闭流

方式2(代码简洁,若读取的文件太大,会抛异常)

image-20231207131730655

image-20231207131845310

总结

image-20231207131940949

2.FileOutputStream(字节输出流)

image-20231207132138643

image-20231207132158771

close()方法关闭流。

示例代码:

1.写单个字节

image-20231207132348406

image-20231207132431199

image-20231207132521977

2.写多个字节(要写回车直接写"\r\n".getBytes())

image-20231207132641461

按需写多个字节

image-20231207133615529

上面的文件写操作都是重新覆盖,要追加文件写的内容,需在下一个参数中填true

image-20231207133701067

要写换行符直接用"\r\n"

image-20231207133901426

文件拷贝案例(字节输入流和字节输出流实现)

image-20231207134228090

image-20231207134718523

实现代码

image-20231207134608594

释放资源

1.try-catch-finally(代码比较复杂,但也可以使用)

image-20231207140333168

2.try-witch-resource(代码简洁)

try-catch执行完成后,会自动执行资源的close()方法

image-20231207141017056

图1-1

image-20231207140912239

格式:

try(

资源

)

资源就是该类实现AutoCloseable接口或者它的父类实现了AutoCloseable也算该子类实现了哦,在代码执行后会自动执行重写的close()方法,如上图1-1。

3.FileReader(字符输入流)

image-20231207142329714

示例代码:

1.每次读单个字符(性能差)

image-20231207142500356

2.每次读多个字符(推荐)

image-20231207142650530

4.FileWtiter(字符输出流)

image-20231207142806167

new FileWriter(File/String, true)中的true表示追加文件内容,默认不填写的话是覆盖文件内容操作。

.write("\r\n");表示写入换行。

示例代码

image-20231207143110167

注意事项

image-20231207143935263

注意:字符流写内容的时候,会先把内容存入内存的一块区域暂时保存,当你调用flush或close方法时,才会真正写入到文件中去。若该内容区域满了,还没刷新或关闭的话,会先把这块区域的内容先写入到文件中去,以便存其他写入内容。

所以它的效率比字节输出流的效率高,因为字节输出流每次写文件内容会调用系统资源往文件里面写内容,而字符输出流可以自己控制写入次数

image-20231207143329583

flush()方法刷新流,使得写入数据生效。刷新后还可以使用该流,也可以多次刷新

image-20231207143634044

close()关闭流,使得写入数据生效。关闭流后,不能在使得该流,否则报错“Stream closed ”

image-20231207143725675

4.缓冲流(提高读写数据的性能)

image-20231207144753118

对原始流进行加工

image-20231207145037974

image-20231207145057183

1.字节缓冲输入、输出流(BufferedInputStream、BufferedOutputStream)

代码不变,多了二行包装代码

image-20231207145251746

可定义缓冲池大小,默认8KB

image-20231207145537576

2.字符缓冲输入、输出流(BufferedReader、BufferedWriter)

1.字符缓冲输入流(BufferedReader)

image-20231207150105677

注意:readLine()是该BufferedReader的独有方法,若用多态写法的话,就不能调用该独有功能了。

示例代码:

image-20231207150406851

独有的readLine()方法,不能用多态写法

image-20231207150521589

readLine()读到结尾会返回null,所以可以配合循环来实现读内容

image-20231207150613184

2.字符缓冲输出流(BufferedWriter)

image-20231207150757320

newLine()是该类的独有方法用于写入换行,要调用该方法不能用多态写法,只能该类变量接收。

5.字符转换流(解决不同编码读取时乱码问题)

注意:该字符转换流是针对原始字节流,因为只有字节流才会出现乱码问题,而不针对字符流(字符流不存在乱码问题)。

该字符转换流可以理解为原始字节输入、输出流的字符流。该流还是低级流,可以用缓存流进行包装

image-20231207152033199

image-20231207151659973

1.字符输入转换流

image-20231207152902100

示例代码:

image-20231207152644846

2.字符输出转换流

image-20231207153210014

image-20231207153005568

示例代码:

image-20231207154012322

6.打印流(往文件里写啥内容就是啥内容,不进行任何转换)——底层自动包装缓存流,高效

如write(97)表示写的是a,而使用打印流write(97)表示可以写的就是这个原始内容97,不进行任何转换。

print(内容)方法表示写入的内容不默认添加换行。而且是该类的独有方法,必须子类变量接收赋值才能使用,多态写法则不能使用该独有方法。

image-20231207154138852

1.PrintStream(字节打印流)

image-20231207154620239

print(内容)方法表示写入的内容不默认添加换行。而且是该类的独有方法,必须子类变量接收赋值才能使用,多态写法则不能使用该独有方法。


示例代码:

  1. 97不进行转换成a,就是原始内容97

    image-20231207155234602

打印后的文件内容为

image-20231207155244498

2.指定写入内容的编码

image-20231207155351055

3.write()会对数字转为ACII码

image-20231207155623112

底层包装了缓存流性能高效。

image-20231207155803955


2.PrintWriter(字符打印流)

image-20231207160240711

print(内容)方法表示写入的内容不默认添加换行。而且是该类的独有方法,必须子类变量接收赋值才能使用,多态写法则不能使用该独有方法。

示例代码:

用法和PrintStream一样

image-20231207160353899

3.追加文件内容的写法

image-20231207160653222

正确方式:

格式为new PrintWriter(文件对象)或PrintStream(文件对象) ,文件对象内部必须设置追加模式,如new FileOutputStream("C:\\a.txt", true)

错误方法:

new PrintWriter(文件对象或字符串路径, true)为错误写法。

4.输出重定向

image-20231207161458599

示例代码:重定向输出到文件

image-20231207161420903

日志文件就是输出重定向到日志文件中记录

7.数据流(常用于数据通信,比较方便)

image-20231207161743823

1.DataOutputStream(数据字节输出流)

image-20231207162110802

要使用独有方法,就不要用多态写法了。

示例代码:

image-20231207162328661

该文件内容还包含了数据类型,以一种特殊形式存储的,不是用来看的

image-20231207162340451

2.DataInputputStream(数据字节输入流)

image-20231207162547950

示例代码:

image-20231207162730685

8.序列化流(及transient关键字)

image-20231207163000933

序列化与反序列化

image-20231207162934648

1.ObjectOutputStrean(序列化流)

image-20231207163741610

类要使用序列化,必须实现Serializable接口。

示例代码:

image-20231207163641625

image-20231207163508608

文件内容

image-20231207163525907

2.ObjectInputStrean(反序列化流)

image-20231207164530594

示例代码:

image-20231207164000620

3.transient关键字

示例理解

image-20231207164401132

image-20231207164454926

3.IO框架

1.定义及方法

image-20231207171222994

image-20231207171242303

2.使用步骤

1.去官方Commons-io官网下载压缩包

image-20231207170533505

2.解压后复制该jar包到项目中去

image-20231207170612447

3.在项目中新建文件夹lib,并右击Add as Library

image-20231207170724519

4.将该jar包复制到该lib文件夹下就能使用了

3.示例代码

image-20231207171203451

这篇关于Java文件流大家族(通俗易懂,学习推荐版,很详细)——操作文件本身和文件中的数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525296

相关文章

Spring三级缓存解决循环依赖的解析过程

《Spring三级缓存解决循环依赖的解析过程》:本文主要介绍Spring三级缓存解决循环依赖的解析过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、循环依赖场景二、三级缓存定义三、解决流程(以ServiceA和ServiceB为例)四、关键机制详解五、设计约

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

史上最全nginx详细参数配置

《史上最全nginx详细参数配置》Nginx是一个轻量级高性能的HTTP和反向代理服务器,同时也是一个通用代理服务器(TCP/UDP/IMAP/POP3/SMTP),最初由俄罗斯人IgorSyso... 目录基本命令默认配置搭建站点根据文件类型设置过期时间禁止文件缓存防盗链静态文件压缩指定定错误页面跨域问题

解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题

《解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:org.junit.Test问题》:本文主要介绍解决tomcat启动时报Junit相... 目录tomcat启动时报Junit相关错误Java.lang.ClassNotFoundException

Gradle下如何搭建SpringCloud分布式环境

《Gradle下如何搭建SpringCloud分布式环境》:本文主要介绍Gradle下如何搭建SpringCloud分布式环境问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Gradle下搭建SpringCloud分布式环境1.idea配置好gradle2.创建一个空的gr

JVM垃圾回收机制之GC解读

《JVM垃圾回收机制之GC解读》:本文主要介绍JVM垃圾回收机制之GC,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、死亡对象的判断算法1.1 引用计数算法1.2 可达性分析算法二、垃圾回收算法2.1 标记-清除算法2.2 复制算法2.3 标记-整理算法2.4

nginx负载均衡及详细配置方法

《nginx负载均衡及详细配置方法》Nginx作为一种高效的Web服务器和反向代理服务器,广泛应用于网站的负载均衡中,:本文主要介绍nginx负载均衡及详细配置,需要的朋友可以参考下... 目录一、 nginx负载均衡策略1.1 基本负载均衡策略1.2 第三方策略1.3 策略对比二、 nginx配置2.1

springboot集成Lucene的详细指南

《springboot集成Lucene的详细指南》这篇文章主要为大家详细介绍了springboot集成Lucene的详细指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起... 目录添加依赖创建配置类创建实体类创建索引服务类创建搜索服务类创建控制器类使用示例以下是 Spring

Java调用Python的四种方法小结

《Java调用Python的四种方法小结》在现代开发中,结合不同编程语言的优势往往能达到事半功倍的效果,本文将详细介绍四种在Java中调用Python的方法,并推荐一种最常用且实用的方法,希望对大家有... 目录一、在Java类中直接执行python语句二、在Java中直接调用Python脚本三、使用Run

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J