在本教程中,我们将借助示例学习Java BufferedInputStream及其方法。
java.io包的BufferedInputStream类与其他输入流一起使用,以更有效地读取数据(以字节为单位)。
它继承了InputStream抽象类。
BufferedInputStream维护一个8192字节的内部缓冲区。
在BufferedInputStream中进行读取操作期间,会从磁盘读取一部分字节并将其存储在内部缓冲区中。 并从内部缓冲区中逐个读取字节。
因此,减少了与磁盘的通信次数。这就是为什么使用BufferedInputStream读取字节更快。
为了创建一个BufferedInputStream,我们必须首先导入java.io.BufferedInputStream包。导入包后,便可以在此处创建输入流。
//创建一个FileInputStream FileInputStream file = new FileInputStream(String path); //创建一个BufferedInputStream BufferedInputStream buffer = new BufferInputStream(file);
在上面的示例中,我们创建了一个名为BufferdInputStream的buffer,并使用名为file的FileInputStream创建了一个文件。
在此,内部缓冲区的默认大小为8192字节。但是,我们也可以指定内部缓冲区的大小。
//创建一个具有指定大小的内部缓冲区的BufferedInputStream BufferedInputStream buffer = new BufferInputStream(file, int size);
buffer将有助于更快地从文件读取字节。
BufferedInputStream类为InputStream类中提供的不同方法提供实现。
read() - 从输入流中读取一个字节
read(byte[] arr) - 从流中读取字节并存储在指定的数组中
read(byte[] arr, int start, int length) - 从流中读取等于length的字节数,并从位置start开始存储在指定的数组中
假设我们有一个名为input.txt的文件,其中包含以下内容。
This is a line of text inside the file.
让我们尝试使用读取文件BufferedInputStream。
import java.io.BufferedInputStream; import java.io.FileInputStream; class Main { public static void main(String[] args) { try { //创建一个FileInputStream FileInputStream file = new FileInputStream("input.txt"); //创建一个BufferedInputStream BufferedInputStream input = new BufferedInputStream(file); //从文件中读取第一个字节 int i = input .read(); while (i != -1) { System.out.print((char) i); //从文件中读取下一个字节 i = input.read(); } input.close(); } catch (Exception e) { e.getStackTrace(); } } }
输出结果
This is a line of text inside the file.
在上面的示例中,我们创建了一个名为buffer的缓冲输入流和FileInputStream。输入流与文件input.txt链接。
FileInputStream file = new FileInputStream("input.txt"); BufferedInputStream buffer = new BufferedInputStream(file);
在这里,我们使用了read()方法从缓冲读取器的内部缓冲区读取字节数组。
要获取输入流中可用字节的数量,我们可以使用available()方法。例如,
import java.io.FileInputStream; import java.io.BufferedInputStream; public class Main { public static void main(String args[]) { try { //假设input.txt文件包含以下文本 //这是文件中的一行文本。 FileInputStream file = new FileInputStream("input.txt"); //创建一个BufferedInputStream BufferedInputStream buffer = new BufferedInputStream(file); //返回可用的字节数 System.out.println("开始时可用的字节数: " + buffer.available()); //从文件中读取字节 buffer.read(); buffer.read(); buffer.read(); //返回可用的字节数 System.out.println("结束时的可用字节数: " + buffer.available()); buffer.close(); } catch (Exception e) { e.getStackTrace(); } } }
输出结果
开始时可用的字节数: 39 结束时的可用字节数: 36
在以上示例中,
我们首先使用available()方法检查输入流中可用字节的数量。
然后,我们使用read()方法3次从输入流中读取3个字节。
现在,在读取字节之后,我们再次检查了可用字节。这一次可用字节减少了3。
要丢弃和跳过指定的字节数,可以使用skip()方法。例如
import java.io.FileInputStream; import java.io.BufferedInputStream; public class Main { public static void main(String args[]) { try { //假设input.txt文件包含以下文本 //这是文件中的一行文本。 FileInputStream file = new FileInputStream("input.txt"); //创建一个BufferedInputStream BufferedInputStream buffer = new BufferedInputStream(file); //跳过5个字节 buffer.skip(5); System.out.println("跳过5个字节后的输入流:"); //从输入流中读取第一个字节 int i = buffer.read(); while (i != -1) { System.out.print((char) i); //从输入流中读取下一个字节 i = buffer.read(); } //关闭输入流 buffer.close(); } catch (Exception e) { e.getStackTrace(); } } }
输出结果
跳过5个字节后的输入流: is a line of text inside the file.
在上面的示例中,我们使用过skip()方法从文件输入流中跳过5个字节。 因此,从输入流中跳过字节“ T”,“ h”,“ i”,“ s”和“ ”。
要关闭缓冲的输入流,我们可以使用close()方法。 一旦调用close()方法,我们将无法使用输入流读取数据。
方法 | 内容描述 |
---|---|
mark() | 标记输入流中已读取数据的位置 |
reset() | 将控件返回到输入流中设置了标记的点 |