字节流只能一次处理一个字节,为了更方便的操作数据,便加入了套接流
问题引入:缓冲流为什么比普通的文件字节流效率高?
不带缓冲的操作,每读一个字节就要写入一个字节,由于涉及磁盘的IO操作相比内存的操作要慢很多,所以不带缓冲的流效率很低。带缓冲的流,可以一次读很多字节,但不向磁盘中写入,只是先放到内存里。等凑够了缓冲区大小的时候一次性写入磁盘,这种方式可以减少磁盘操作次数,速度就会提高很多!这就是两者的区别
另外一个网友的解释:
没有缓存区,那么每read一次,就会发送一次IO操作;
有缓存区,第一次read时,会一下读取x个字节放入缓存区,然后后续的read都会从缓存中读取,当read到缓存区末尾时,会再次读取x个字节放入缓存区。
很明显,第二种方式,会减少IO操作,效率更高,缺点就是,内存占用的多。
FilterInputStream和FilterOutputStream
1.BufferedInputStream和bufferedOutputStream
特点:
1.为输入和输出创建缓冲
2.缓冲不够自动加长
3.一次读取一堆字节
4.就是过滤流
5.只读取文本文件
对于buffer流,只有缓冲区满时,才会将数据真正到输出流,但可以使用flush()方法人为的将尚未填满的缓冲区中的数据送出
还是不能一次读取一行,只能读取文本文件
且不能确定文件的编码方式,在网络上难以应用
实际中用的最多的还是:data流可以让发送方和接收方按照同一的编码去处理
DataInputStream和DataOutputStream
1.可以接受一行的数据
2.可以对其进行编码
3.也是套接流,可以套接文件字节流和网络字节流
4.读写的顺序要一致,否则读取会出现异常
DataInputStream 的作用就是“允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型。应用程序可以使用数据输出流写入稍后由数据输入流读取的数据。”
DataInputStream 中比较难以理解的函数就只有 readUTF(DataInput in);下面,对这个函数进行详细的介绍,其它的函数请参考源码中的注释。
buffer流只能读取若干字节的数据,处理文本文件,套接标准字节流
Data 可以处理二进制和文本文件,可以读取一行的字符,套接网络上和文件上
FileOutputStream fos = new FileOutputStream("a.txt");
DataOutputStream dos = new DataOutputStream (fos);
try//IO操作,要用try捕捉异常
{
dos.writeBoolean(true);//
dos.writeByte((byte)123);//
dos.writeChar('J');//
dos.writeDouble(3.141592654);//
dos.writeFloat(2.7182f);
dos.writeInt(1234567890);
dos.writeLong(998877665544332211L);
dos.writeShort((short)11223);
//以二进制的方式存储到文件中,看不见
}
finally
{
dos.close();
}
FileInputStream fis = new FileInputStream("a.txt");//没有声明异常,因为抛出了异常
DataInputStream dis = new DataInputStream(fis);
try
{
System.out.println("\t "+dis.readBoolean());
//System.out.println("\t "+dis.readByte());//如果读取的方式和存储的方式不一致,则读取会出现异常
System.out.println("\t "+dis.readChar());
System.out.println("\t "+dis.readDouble());
System.out.println("\t "+dis.readFloat());
System.out.println("\t "+dis.readInt());
System.out.println("\t "+dis.readLong());
System.out.println("\t "+dis.readShort());
}
finally
{
dis.close();
}