通常来说,我们认为字节流的功能比字符串功能强大,因为
计算机里所有的数据都是二进制的,而字节流可以处理所有的二进制文件
但问题是如果我们使用字节流来处理文本文件时,我们需要使用合适的方式把这些字节转换成字符,这样增加了编程的复杂度。所以如果需要进行输入输出的
内容是文本内容,则考虑使用字符流,如果需要进行输入输出的是二进制内容,则应该考虑使用字节流。
我们把计算机的文件分为文本文件和二进制文件两大类
所有能用记事本打开并看到其中字符内容的文件我们称为文本文件,反之则为
二进制文件、但实质上计算机的所有文件都是二进制文件,文本文件只是
二进制文件的一种特例,当二进制文件里的内容恰好能被正常解析是则
该二进制文件就变成了文本文件。
Java IO 的一般使用原则 :
一、按数据来源(去向)分类:
1 、是文件: FileInputStream, FileOutputStream, ( 字节流 )FileReader, FileWriter( 字符 )
2 、是 byte[] : ByteArrayInputStream, ByteArrayOutputStream( 字节流 )
3 、是 Char[]: CharArrayReader, CharArrayWriter( 字符流 )
4 、是 String: StringBufferInputStream, StringBufferOuputStream ( 字节流 )StringReader, StringWriter( 字符流 )
5 、网络数据流: InputStream, OutputStream,( 字节流 ) Reader, Writer( 字符流 )
二、按是否格式化输出分:
1 、要格式化输出: PrintStream, PrintWriter
三、按是否要缓冲分:
1 、要缓冲: BufferedInputStream, BufferedOutputStream,( 字节流 ) BufferedReader, BufferedWriter( 字符流 )
四、按数据格式分:
1 、二进制格式(只要不能确定是纯文本的) : InputStream, OutputStream 及其所有带 Stream 结束的子类
2 、纯文本格式(含纯英文与汉字或其他编码方式); Reader, Writer 及其所有带 Reader, Writer 的子类
五、按输入输出分:
1 、输入: Reader, InputStream 类型的子类
2 、输出: Writer, OutputStream 类型的子类
六、特殊需要:
1 、从 Stream 到 Reader,Writer 的转换类: InputStreamReader, OutputStreamWriter
2 、对象输入输出: ObjectInputStream, ObjectOutputStream
3 、进程间通信: PipeInputStream, PipeOutputStream, PipeReader, PipeWriter
4 、合并输入: SequenceInputStream
决定使用哪个类以及它的构造进程的一般准则如下(不考虑特殊需要):
首先,考虑最原始的数据格式是什么
第二,是输入还是输出
第三,是否需要转换流
第四,数据来源(去向)是什么
第五,是否要缓冲(特别注明:一定要注意的是 readLine() 是否有定义,有什么比 read, write 更特殊的输入或输出方法)
第六,是否要格式化输出 |