java的IO之包装流和缓存流
程序员文章站
2024-03-06 23:58:02
...
1.处理流/包装流(相对于节点流更高级)装饰设计模式/包装模式
1:隐藏了底层的节点流的差异,并对外提供了更方便的输入/输出功能,让我们只关心高级流的操作.2:使用处理流包装了节点流,程序直接操作处理流,让节点流与底层的设备做IO操作.
3:只需要关闭处理流即可.
包装流如何区分:写代码的时候,发现创建对象对象的时候,需要传递另一个流对象.
new 包装流( 流对象 ) ;
-----------------------------------------------------------
什么是缓冲流:
是一个包装流,目的起缓冲作用.
BufferedInputStream:
BufferedOutputStream:
BufferedReader:
BufferedWriter:
缓冲流的目的:
操作流的时候,习惯定义一个byte/char数组.
int read():每次都从磁盘文件中读取一个字节. 直接操作磁盘文件性能极低.
解决方案: 定义一个数组作为缓冲区.
byte[] buffer = new byte[1024]; 该数组其实就是一个缓冲区.
一次性从磁盘文件中读取1024个字节. 如此以来,操作磁盘文件的次数少了,---->性能得以提升.
既然我们都能想到,SUN公司早就想到了,提供的默认缓存区大小是8192(1024*8),我们一般不用修改大小.
字节缓冲流复制案例:
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
public class IODemo4 {
public static void main(String[] args) {
//这里我使用了JDK1.7新特性:自动关闭资源,将资源的创建放到try语句的()中,资源使用完毕之后会自动关闭,不用我们手动释放
try
(
//创建源
InputStream in = new BufferedInputStream(new FileInputStream("a.txt"));
//创建目标
OutputStream out = new BufferedOutputStream(new FileOutputStream("aCopy.txt"));
)
{
byte[] by =new byte[1024];
int len=0;
while ((len=in.read(by))!=-1) {
out.write(by, 0, len);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
字符缓冲流复制案例:字符缓冲中有新的方法,想要使用这些方法就不能使用面向接口编程,就要直接创建它的对象
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
public class IODemo5 {
public static void main(String[] args) {
//这里我使用了JDK1.7新特性:自动关闭资源,将资源的创建放到try语句的()中,资源使用完毕之后会自动关闭,不用我们手动释放
try
(
//创建源
BufferedReader reader = new BufferedReader(new FileReader("file.txt"));
//创建目标
BufferedWriter writer = new BufferedWriter(new FileWriter("fileCopy.txt"));
)
{
String len = null;
while ((len=reader.readLine())!=null) { //读取一行
writer.write(len); //写出一行
writer.newLine(); //换行
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
上一篇: 字符编码和字符集
下一篇: 优惠券优惠的思路以及实践