アウトライン
また、高流量としても知られている緩衝ストリームは、実質的にFileXxx 4ストリームを向上し、ストリームは、データ型の分類によれば、4:
- バイトストリームバッファ:BufferedInputStreamを、なBufferedOutputStream
- ストリームバッファの文字:BufferedReaderの、BufferedWriterの
バッファフローの基本原則とメリット
- あなたはストリームオブジェクトを作成すると、ある読み書きの効率を改善するために内蔵されたバッファ配列のデフォルトサイズシステムIOの数を減らすために、読み書きにより、作成されます。
BufferedOutputStreamがバイトバッファリングされた出力ストリーム
一般的な方法java.io.BufferedOutputStreamは、親クラスから継承したOutputStreamメンバーを拡張します。
- 公共空に近い():この出力ストリームを解放ストリームに関連するすべてのシステムリソースを閉じます。
- 公共のボイドフラッシュ():バッファされた出力が書き込まれるバイト出力ストリームと力をフラッシュします。
- 公共ボイドライト(バイト[] B):指定されたバイト配列からこの出力ストリームへのb.lengthバイト。
- ボイド一般書き込み(オフINT、バイト[] BをINT LEN) :指定されたバイト配列からの書き込みから始まるバイトlenの出力ストリームからのこの出力にオフセットoff。
- 公共の抽象無効書き込み(INT B):バイトの指定された出力ストリーム。
一般的な工法
- なBufferedOutputStream(OutputStreamをアウト)指定された基本となる出力ストリームに書き込みデータへのバッファリングされた出力ストリームを作成します。
- なBufferedOutputStream(OutputStreamのうち、int型のサイズ)のバッファリングされた出力ストリームを作成し、データが出力ストリームの基礎となる指定されたバッファサイズで指定された書かれています。
- OutputStreamから:バイトの出力ストリーム、我々はのFileOutputStreamを渡すことができますが、バッファフローは、書き込み効率のFileOutputStreamを向上させること、のFileOutputStreamバッファを増加します。
- int型のサイズ:指定したストリームバッファの内部バッファのサイズは、デフォルト値を指定されていません
使用ステップ(強調)
- 出力先となるバインドされたFileOutputStreamオブジェクトのコンストラクタを作成します。
- 効率を改善するためのFileOutputStreamオブジェクトオブジェクトのFileOutputStreamオブジェクトを渡すなBufferedOutputStreamオブジェクトのコンストラクタを作成します
- 使用データが内部バッファに書き込まれ、ライトなBufferedOutputStreamオブジェクトは、
- フラッシュなBufferedOutputStreamオブジェクト、内部データバッファ、ファイルへの更新を使用します
- リソースの解放は、(データを更新するために、第1フラッシュ法と呼ばれる、最初の4つは省略されてもよいです)
コードは示しています。
パッケージdemo01; インポートjava.io.BufferedOutputStream; インポートjava.io.FileOutputStreamは、 インポートにjava.io.IOException; パブリック クラスDemo01BufferedOutputStream { 公共 静的 ボイドメイン(文字列[]引数)がスローにIOException { // 指定したFileOutputStreamオブジェクトを作成して出力します先 たFileOutputStream FOS = 新しい新たFileOutputStream( "\\ atxt day21。" ); // 2のFileOutputStreamオブジェクトの効率向上、オブジェクトを渡しなBufferedOutputStreamオブジェクトコンストラクタのFileOutputStreamオブジェクトを作成 =なBufferedOutputStream BOSを新しい新規なBufferedOutputStream(FOS)を、 // 内部バッファへの書き込みデータ bos.write(「中国の上昇を読み取る---恩来」.getBytes()); // バイト配列に文字列 / * 使用フラッシュのなBufferedOutputStreamオブジェクト、データバッファ、ファイルへのリフレッシュ内部 bos.flush(); 5.リリースリソース(最初の呼び出しフラッシュは、データを更新され、第四の部分が省略されてもよい) * / bos.close(); } }
コード実行の結果
BufferedInputStreamを:バイトバッファリングされた入力ストリーム
java.io.BufferedInputStreamののInputStreamは延びて、親クラスのメンバメソッドから継承されました:
- int型の読み取りは、()入力ストリームからデータの次のバイトを読み込みます。
- INTは読み取り(バイト[] B)バイトの数は、入力ストリームから読み出され、バッファ配列bに格納します。
- ボイドクローズ()この入力ストリームを閉じて、ストリームに関連するすべてのシステムリソースを解放します。
共通のコンストラクタ:
- BufferedInputStreamを(で入力ストリームは)BufferedInputStreamを作成し、後で使用するために、その引数である入力ストリームを保存します。
- BufferedInputStreamを(int型のサイズ、における入力ストリーム)にBufferedInputStreamは、指定されたバッファサイズで作成され、後で使用するために、その引数である、すなわち、入力ストリームを保存します。
コンストラクタのパラメータ:
- InputStream:入力バイトストリームオブジェクト、我々はのFileInputStreamを渡すことができ、バッファフローは、FileInputStreamをの読み取り効率を向上させるために、FileInputStreamのバッファを増加します
- int型のサイズ:指定バッファフローの内部バッファのサイズは、デフォルトのサイズを指定しないでください。
使用ステップ(強調):
- 読み取るために、データソースをバインドするのFileInputStreamオブジェクトのコンストラクタを作成します。
- BufferedInputStreamを読み取りオブジェクトのFileInputStreamの効率を向上させ、オブジェクトを渡すオブジェクトのコンストラクタのFileInputStreamを作成しました
- 使用して、ファイルを読み取るために、BufferedInputStreamをオブジェクトを読んで
- リソースを解放
コードは示しています。
ファイル読みファーストレディ(一般的に使用される文字が示すバイトのファイルを、中国は簡単に文字化け)
コードの実装
package demo01; import java.io.BufferedInputStream; import java.io.FileInputStream; import java.io.IOException; public class Demo01BufferedInputStream { public static void main(String[] args) throws IOException { //1.创建FileInputStream对象,构造方法中绑定要读取的数据源 FileInputStream fis = new FileInputStream("day21\\b.txt"); //2.创建BufferedInputStream对象,构造方法中传递FileInputStream对象,提高FileInputStream对象的读取效率 BufferedInputStream bis = new BufferedInputStream(fis); //3.使用BufferedInputStream对象中的方法read,读取文件 int len = 0;//记录每次读取的字节 //从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。 byte[] b = new byte[1024];//定义数组,存储每次读取的数据 //循环读取 while ((len = bis.read(b)) != -1) { //输出读取的数据,并且转化为字符串 System.out.println(new String(b, 0, len)); } //释放资源 bis.close(); } }
代码执行后的结果
利用缓冲流复制文件
代码演示
package demo01; import java.io.*; public class BufferedDemo { public static void main(String[] args) throws FileNotFoundException { // 记录开始时间 long start = System.currentTimeMillis(); // 创建流对象 try ( BufferedInputStream bis = new BufferedInputStream(new FileInputStream("C:\\1.txt")); BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream("D\\copy.exe")); ) { // 读写数据 int len; byte[] bytes = new byte[8 * 1024]; while ((len = bis.read(bytes)) != -1) { bos.write(bytes, 0, len); } } catch (IOException e) { e.printStackTrace(); } // 记录结束时间 long end = System.currentTimeMillis(); System.out.println("缓冲流使用数组复制时间:" + (end - start) + " 毫秒"); } }
BufferedWriter:字符缓冲输出流
java.io.BufferedWriter extends Writer继承自父类的共性成员方法:
- void write(int c) 写入单个字符。
- void write(char[] cbuf)写入字符数组。
- abstract void write(char[] cbuf, int off, int len)写入字符数组的某一部分,off数组的开始索引,len写的字符个数。
- void write(String str)写入字符串。
- void write(String str, int off, int len) 写入字符串的某一部分,off字符串的开始索引,len写的字符个数。
- void flush()刷新该流的缓冲。
- void close() 关闭此流,但要先刷新它
常用构造方法:
- BufferedWriter(Writer out) 创建一个使用默认大小输出缓冲区的缓冲字符输出流。
- BufferedWriter(Writer out, int sz) 创建一个使用给定大小输出缓冲区的新缓冲字符输出流。
构造方法参数:
- Writer out:字符输出流,我们可以传递FileWriter,缓冲流会给FileWriter增加一个缓冲区,提高FileWriter的写入效率
- int sz:指定缓冲区的大小,不写默认大小
特有的成员方法:
- void newLine() 写入一个行分隔符。会根据不同的操作系统,获取不同的行分隔符
使用步骤:
- 创建字符缓冲输出流对象,构造方法中传递字符输出流
- 调用字符缓冲输出流中的方法write,把数据写入到内存缓冲区中
- 调用字符缓冲输出流中的方法flush,把内存缓冲区中的数据,刷新到文件中
- 释放资源
代码演示
package demo01; import java.io.BufferedWriter; import java.io.FileWriter; import java.io.IOException; public class Demo01BufferedWriter { public static void main(String[] args) throws IOException { //1.创建字符缓冲输出流对象,构造方法中传递字符输出流 BufferedWriter bw = new BufferedWriter(new FileWriter("day21\\c.txt")); //2.调用字符缓冲输出流中的方法write,把数据写入到内存缓冲区中 for (int i = 0; i < 5; i++) { //利用for循环写5遍,中国崛起 bw.write("中国崛起" + i); //特意方法换行 bw.newLine(); } //释放资源 bw.close(); } }
代码执行后的结果
BufferedReader:字符缓冲输入流
java.io.BufferedReader extends Reader继承自父类的共性成员方法:
- int read() 读取单个字符并返回。
- int read(char[] cbuf)一次读取多个字符,将字符读入数组。
- void close() 关闭该流并释放与之关联的所有资源。
构造方法:
- BufferedReader(Reader in) 创建一个使用默认大小输入缓冲区的缓冲字符输入流。
- BufferedReader(Reader in, int size) 创建一个使用指定大小输入缓冲区的缓冲字符输入流。
参数:
- Reader in:字符输入流我们可以传递FileReader,缓冲流会给FileReader增加一个缓冲区,提高FileReader的读取效率
- int size:指定缓冲区大小
特有的成员方法:
String readLine() 读取一个文本行。读取一行数据行的终止符号。通过下列字符之一即可认为某行已终止:换行 ('\n')、回车 ('\r') 或回车后直接跟着换行(\r\n)。返回值:包含该行内容的字符串,不包含任何行终止符,如果已到达流末尾,则返回 null
使用步骤:
- 创建字符缓冲输入流对象,构造方法中传递字符输入流
- 使用字符缓冲输入流对象中的方法read/readLine读取文本
- 释放资源
代码演示
package demo01; import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; public class Demo01BufferedReader { public static void main(String[] args) throws IOException { //1.创建字符缓冲输入流对象,构造方法中传递字符输入流\ BufferedReader br = new BufferedReader(new FileReader("day21\\c.txt")); /* 发下以上读取是一个重复的过程,所以可以使用循环优化 不知道文件中有多少行数据,所以使用while循环 while的结束条件,读取到null结束 */ String s; //定义变量,记录每次读取的数据 while ((s = br.readLine()) != null) { System.out.println(s); } //释放资源 br.close(); } }
代码执行的结果
练习:文本排序
代码实现
package demo01; import java.io.*; import java.util.HashMap; /* 练习: 对文本的内容进行排序 按照(1,2,3....)顺序排序 分析: 1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3,..);value:存储每行的文本 2.创建字符缓冲输入流对象,构造方法中绑定字符输入流 3.创建字符缓冲输出流对象,构造方法中绑定字符输出流 4.使用字符缓冲输入流中的方法readline,逐行读取文本 5.对读取到的文本进行切割,获取行中的序号和文本内容 6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4..) 7.遍历HashMap集合,获取每一个键值对 8.把每一个键值对,拼接为一个文本行 9.把拼接好的文本,使用字符缓冲输出流中的方法write,写入到文件中 10.释放资源 */ public class Test { public static void main(String[] args) throws IOException { //1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3,..);value:存储每行的文本 HashMap<String, String> map = new HashMap<>(); //2.创建字符缓冲输入流对象,构造方法中绑定字符输入流 BufferedReader br = new BufferedReader(new FileReader("day20\\a.txt")); //3.创建字符缓冲输出流对象,构造方法中绑定字符输出流 BufferedWriter bw = new BufferedWriter(new FileWriter("day20\\b.txt")); //4.使用字符缓冲输入流中的方法readline,逐行读取文本 String line; while ((line = br.readLine()) != null) { //5.对读取到的文本进行切割,获取行中的序号和文本内容 String[] arr = line.split("\\."); //6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4..) map.put(arr[0], arr[1]); } //7.遍历HashMap集合,获取每一个键值对 for (String key : map.keySet()) { String value = map.get(key); //8.把每一个键值对,拼接为一个文本行 line = key + "." + value; //9.把拼接好的文本,使用字符缓冲输出流中的方法write,写入到文件中 bw.write(line); bw.newLine();//写换行 } //10.释放资源 bw.close(); br.close(); } }