BufferedOutputStream ————字节缓冲输出流
继承自父类的共性方法
public void close()——关闭此输出流并释放与此流相关联的任何系统资源。
public void flush()——刷新此输出流并强制任何缓冲的输出字节被写出。
public void write(byte[ ] b)——将b.length字节从指定的字节数组写入到此输出流。
public void write(byte[ ] b,int off,int len)——从指定的字节数组写入len字节,从偏移量off开始输出到此输出流。
public abstract void write(int b)——将指定的字节输出流。
构造方法
BufferedOutputStream (OutputStream out)——创建一个新的缓冲输出流,以将数据写入指定的底层输出流。
BufferedOutputStream (OutputStream out,int
size)——创建一个新的缓冲输出流,以将具有指定缓冲区大小的数据写入指定的底层输出流。
参数
OutputStream out————字节输出流
我们可以传递FileOutPutStream,缓冲流会给FileOutPutStream增加一个缓冲区,提高FileOutPutStream的写入效率。
int size—————————指定缓冲流内部缓冲区的大小,不指定默认。
使用步骤(重点)
1.创建FileOutPutStream对象,构造方法中绑定要输出的目的地。
2.创建BufferedOutputStream对象,构造方法中传递FileOutPutStream对象,提高FileOutPutStream对象效率。
3.使用BufferedOutputStream对象中的方法write,把数
据写入到内部缓冲区中。
4.使用BufferedOutputStream对象中的方法flush,把内部缓冲区中的数据,刷新到文件中。
5.释放资源(会先调用flush方法刷新数据,第四步可以省略)。
java.io.BufferedIutputStream extends IutputStream
BufferedIntputStream ————字节缓冲输入流
继承自父类的共性方法
int read()——从输入流中读取数据的下一个字节。
int read(char[ ] cbuf)——从输入流中读取一定数量的字节,并将其存储在缓冲区数组b中。
void close()——关闭此输入流并释放与此流相关联的任何系统资源。
构造方法
BufferedIntputStream (IutputStream in)——创建一个BufferedIntputStream 并保存其参数,即输入流in,以便将来使用。
BufferedIntputStream (IntputStream in,int
size)——创建具有指定缓冲区大小的BufferedIntputStream 保存其参数,即输入流in。
参数
IntputStream in————字节输入流
我们可以传递FileIntPutStream,缓冲流会给FileIntPutStream增加一个缓冲区,提高FileIntPutStream的读取效率。
int size—————————指定缓冲流内部缓冲区的大小,不指定默认。
使用步骤(重点)
1.创建FileIntPutStream对象,构造方法中绑定要读取的数据。
2.创建BufferedIntputStream 对象,构造方法中传递FileIntPutStream对象,提高FileIntPutStream对象读取效率。
3.使用BufferedIntputStream 对象中的方法read,读取文件
4.释放资源。
java.io.BufferedWriter extends Writer
字符缓冲输出流——BufferedWriter类
继承自父类的共性成员方法
public void write(int c)—————写入单个字符。
public void write(char[ ] cbuf)——写入字符数组。
abstract void write(char[ ] cbuf,int off,int len)——写入字符数组的某一部分,off数组的开始索引,len写的字符个数。
void write(String str)——写入字符串。
void write(char[ ] cbuf,int off,int len)——写入字符数组的某一部分,off字符串的开始索引,len写的字符个数。
void flush()——刷新该流的缓冲。
public void close()————————关闭此流,但要先刷新它。
构造方法
BufferedWriter (Writer out)————创建一个使用默认大小输出缓冲区的缓冲字符输出流。
BufferedWriter (Writer out,int sz)——创建一个使用给定大小输出缓冲区的缓冲字符输出流。
参数
Writer out————字符输出流
我们可以传递FileWtite,缓冲流会给FileWtite增加一个缓冲区,提高FileWtite的写入效率。
int sz—————指定缓冲区的大小,不写默认大小。
特有的成员方法
void newLine()————写入一个行分隔符。会根据不同的操作系统,获取不同的行分隔符。
使用步骤
1.创建字符缓冲输出流对象,构造方法中传递字符输出流。
2.调用字符缓冲输出流对象的方法write,把数据写入到缓冲区中。
3.调用字符缓冲输出流对象的方法flush,把内存缓冲区中的数据,刷新到文件中。
4.释放资源。
java.io.BufferedReader extends Reader
字符输入流——BufferedReader 类
继承自父类的共性成员方法
int read()——读取单个字符并返回。
int read(char[ ] cbuf)——一次读取多个字符,将字符读入数组。
void close()——关闭该流并释放与之关联的所有资源。
构造方法
BufferedReader (Reader in)————创建一个使用默认大小的输入缓冲区的缓冲字符输入流。
BufferedReader (Reader in)————创建一个使用是定大小输入缓冲区的缓冲字符输入流。
参数——————读取文件的数据源
Reader in——字符输入流
我们可以传递FileReader,缓冲流会给FileReader增加一个缓冲区,提高FileReader的读取效率。
特有的成员方法
String readLine( )——————读取一个文本行。读取一行数据。
行的终止符号—————————通过下列字符即可认为某行已终止————换行(‘\n’)、回车(‘\r’)或者回车后直接跟着换行(\n\r)。
返回值
包含改行内容的字符串,不包含任何终止符,如果已达流末尾,则放回null。
使用步骤
1.创建一个字符缓冲输入流对象,构造方法中传递符缓冲输入流。
2.使用符缓冲输入流对象中的方法read/readLine读取文本。
3.释放资源。
练习——对文本的内容进行排序
package cn.lrf.IODemo;
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 Demo05Test {
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("day08-code\\src\\cn\\lrf\\IODemo\\c.txt"));
//3.创建字符缓冲输出流对象,构造方法中绑定字符输入流。
BufferedWriter bw = new BufferedWriter(new FileWriter("day08-code\\src\\cn\\lrf\\IODemo\\d.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();
}
}
来源:http://www.cnblogs.com/sy130908/p/11497059.html