(更多内容请关注本人微信订阅号:it_pupil)
你没进错,我们讲的是Java的输入输出流。
概述
➤ 可以从其中读入一个字节序列的对象称作输入流。(输入流是一个对象,可以从这个对象中读取一个字节序列。)
➤ 可以向其中写入一个字节序列的对象称作输出流。
➤ 读入或者写入的字节序列当然有个来源地和目的地(输入流从哪里读取字节序列的,输入流把字节序列写入到哪里去?),这个来源地和目的地可以是文件(通常)、网络链接,内存块等。
➤ 抽象类InputStream和OutputStream是输入输出流层次结构的基础(祖宗)。
➤ 从上面看出,输入输出流以字节为单位,那么,它们就不方便处理以Unicode形式存储的信息(用两个字节来编码一个字符。),所以,从抽象类Reader和Writer中又继承出来一个层次架构,专门处理这种Unicode字符。这些类的读入与写出是基于两字节码元的,而不是单字节字符。
读写字节
➤ InputStream只有一个抽象的读方法:abstract int read();
➤ 设计具体的输入流,必须覆盖read()方法。比如:FileInputStream覆盖read()增加了功能:从文件中读字节。
➤ InputStream还有若干个非抽象的方法,比如,读入一个字节数组啊,跳过大量的字节再开始读入啊等,而这些方法都调用了抽象的read()方法,所以,各个子类只需要覆盖read()方法。
➤ 与InputSDtream类似,OutputStream定义了抽象写方法:abstract void write(int b);
➤ 完成读写后,要调用close方法关闭流,释放资源。
➤ read和write方法操作时都将被阻塞(线程安全),直至字节确实被读入或者写出,可以用available方法事先检查可读入的字节数量。
➤ close在关闭流的同时,还会把输出缓冲区的字符全部全部强制推出去。如果不关闭,那么缓冲区的最后留下的数据可能永远不会传送出去了。
➤ 可以用flush()方法强制把缓冲区的数据冲刷出去。
完整的流家族
➤ 读写单个字节或字节数组:InputStream和OutputStream。
➤ 读写字符串和数字:扩展InputStream和OutputStream,生成丰富的子类,如:
DataInputStream和DataOutputStream:以二进制格式读写所有的Java基本类型。
ZipInputStream,ZipOutputStream:读写Zip文件。
➤ 上面不论是祖宗还是子孙,均以字节或者字节数组为读取目标。读取Unicode文本呢(以双字节为码元):使用Reader和Writer的子类。
组合流过滤器
➤ FileInputStream可以按字节读取文件中的数据,但是没法读取数值类型。
➤ DataInputStream可以读入数值类型(readDouble()等),但是它不能从文件中读取数据啊。
➤ 那么我现在想从文件中读入数字,怎么破?那就套一层:
➤ 我不但要从文件中读入数字,我还要在读取过程中利用缓冲区缓存数据,怎么破?那就继续套:
➤ 上面的一层套一层的方式,其实是Java经典的设计模式:装饰者模式的应用:
原文链接:
http://mp.weixin.qq.com/s?__biz=MzIyNzUzNjQ3MA==&mid=2247483849&idx=1&sn=656bf330b2851fa301efcff257a1222f&scene=21#wechat_redirect