【JAVA学习之路 | 进阶篇】节点流与缓冲流(处理流之一)

简介: 【JAVA学习之路 | 进阶篇】节点流与缓冲流(处理流之一)

1.节点流.

节点流又称文件流.四个文件流对应着四个抽象基类

抽象基类                节点流
 
InputStream            FileInputStream
 
OutputStream           FileOutputStream
 
Reader                 FileReader
 
Writer                 FileWriter

2.文件流的使用.

(1). FileReader : 输入字符流.

FileReader是输入字符流.数据传输以字符为单位,所以用char型数组接受.对应的方法有read(char[] cbuffer)读取数据到内存.close()关闭流.

例 : char[] cbuffer = new char[5];每次从文件中读取5个字符到内存中.

@Test
    public void test4(){
        FileReader fr = null;
        try {
            File file = new File("src/hello.txt");
            fr = new FileReader(file);
//            int data;
//            while((data = fr.read()) != -1) {
//                System.out.println((char) data);
//            }
            char[] cbuffer = new char[5];
            int len = 0;
            while(len != -1) {
                len = fr.read(cbuffer);
                for (int i = 0; i < len; i++) {
                    System.out.print(cbuffer[i]);
                }
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            try {
                if (fr != null) {
                    fr.close();
                }
            } catch (IOException e) {
                throw new RuntimeException(e);
            }
        }

(2). FileWriter : 输出字符流


FileWriter是输出字符流.也用到char型数组.对应的方法有write(char[] cbuffer, 0, len) / write(String str)将数据写入文件.close关闭流.


char[] cbuffer = new char[5];//每次以五个字符输出到文件中.


(3). FileInputStream : 输入字节流.


FileInputStream是输入字节流.数据传输以字节为单位,用到byte[]数组.对应的方法同样是read(byte[] cbuffer)将文件的内容读取到内存中.close()关闭流.


(4). FileOutputStream : 输出字节流.


FileOutputStream是输出字节流.用到byte型数组.方法为write(byte[] cbuffer, 0, len)/Write(String str)将数据写入文件.close()关闭流.

3.执行步骤

  1. 创建读取或写出的文件对象
  2. 创建输入流或输出流.
  3. 具体的读入/写出功能.
  4. 关闭流资源,避免内存泄露.

4.注意

(1).

一般来说,输出流调用write(参数列表)时,会覆盖文件(而不是覆盖文件内容).按住Ctrl+p,发现FileWriter可以放入append参数.默认的是false.如果显式的在形参列表中放入true的话,将不会覆盖文件,而是在其现有的文件内容的基础上,追加文件内容.


(2). 涉及到流资源关闭的操作时,需要用try-catch-finally来处理异常.


(3). 对于输入流来说,要求File类的对象对应的磁盘的文件中必须真实存在.否则会报异常.


(4). 对输出流来说,File类的对象对应的物理磁盘中的文件可以不存在.如果不存在,则创建该文件,并将数据写到该文件上.如果存在且FileWriter(File fw, false),在输出数据的过程中,新建同名的文件对已有的文件进行覆盖.如果FileWriter(File fw, true),则会在现有的文件内容的基础上追加数据.


(5).

  • 对于字符流来说,只能操作文本文件,不能用来处理非文本文件.如".txt",".java"结尾.
  • 对于字节流来说,可以操作文本和非文本文件.如".jpg",".doc"结尾.

5.缓冲流.

缓冲流是处理流.

节点流                    缓冲流
 
FileInputStream          BufferedInputStream
 
FileOutputStream         BufferedOutputStream
 
FileReader               BufferedReader
 
FileWriter               BufferedWriter

创建缓冲流对象.

File file = new File("src/hello.txt");
 
FileReader fw = new FileWriter(file);
//节点流
FileWriter fw = new FileWriter(file);
//缓冲流
BufferedWriter bfw = new BufferedWriter(fw);

注 :

  • 其他缓冲流对象的创建与上相似.
  • 关闭了外部的处理流(bfw.close),内部流(fw)无需手动关闭.
  • 缓冲流对比节点流来说,处理数据的速度更快.因为其减少了与磁盘的交互次数,所以速度更快.比如节点流的长度为5的char型数组,每传输五个字符的数据就要与磁盘交互一次.
  • 对缓冲流的操作步骤与节点流类似.在此不做展示了.

缓冲区及作用 :

缓冲区 : 内部提供了一个数组,将读取或要写入的数据在此数组中缓存,达到一定程序时,集中性写出.

作用 : 减少磁盘的交互速度,进而提升读取速度.

相关文章
|
3月前
|
XML Java 编译器
Java学习十六—掌握注解:让编程更简单
Java 注解(Annotation)是一种特殊的语法结构,可以在代码中嵌入元数据。它们不直接影响代码的运行,但可以通过工具和框架提供额外的信息,帮助在编译、部署或运行时进行处理。
109 43
Java学习十六—掌握注解:让编程更简单
|
3月前
|
存储 SQL 小程序
JVM知识体系学习五:Java Runtime Data Area and JVM Instruction (java运行时数据区域和java指令(大约200多条,这里就将一些简单的指令和学习))
这篇文章详细介绍了Java虚拟机(JVM)的运行时数据区域和JVM指令集,包括程序计数器、虚拟机栈、本地方法栈、直接内存、方法区和堆,以及栈帧的组成部分和执行流程。
49 2
JVM知识体系学习五:Java Runtime Data Area and JVM Instruction (java运行时数据区域和java指令(大约200多条,这里就将一些简单的指令和学习))
|
2月前
|
Java 大数据 API
14天Java基础学习——第1天:Java入门和环境搭建
本文介绍了Java的基础知识,包括Java的简介、历史和应用领域。详细讲解了如何安装JDK并配置环境变量,以及如何使用IntelliJ IDEA创建和运行Java项目。通过示例代码“HelloWorld.java”,展示了从编写到运行的全过程。适合初学者快速入门Java编程。
|
2月前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
2月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
3月前
|
小程序 Oracle Java
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
这篇文章是关于JVM基础知识的介绍,包括JVM的跨平台和跨语言特性、Class文件格式的详细解析,以及如何使用javap和jclasslib工具来分析Class文件。
63 0
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
|
3月前
|
存储 算法 Java
带你学习java的数组军队列
带你学习java的数组军队列
43 0
|
3月前
|
Java 大数据 开发工具
java学习——环境准备(1)
java学习——环境准备(1)
45 0
|
4天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
42 17
|
15天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
下一篇
开通oss服务