1、 流按照方向来分,分为几种?相对于什么而言?按照流传输数据的类型来分,分为几种?
流按照传输方向分为输入流和输出流,以内存做为参照物,当数据从数据源中读取到内存中,
叫输入流,也叫读取流,当将内存中的数据写入到数据流中,叫输出流也叫写入流。
按照传输内容分为字节流,字符流,对象流。
2、 流相关的操作类在哪个包中?字节流和字符流的父类是什么?
流相关的操作类在Java。io包中,字节流有两个父类,inputsteam(读取字符流)和outputsteam(写入流)
字符流也有两个父类,read(读取字符流)和writer(写入字符流)。
3、 为什么字节流和字符流的父类是抽象类?
字节流和字符流写入和读取的方式都不一样,所以需要子类重写。
4、 字节流方法中,read()和read(byte[] b)返回类型,各自是什么含义?
read() : 从输入流中读取数据的下一个字节,返回0到255范围内的int字节值。如果因为已经到达流末尾而没有可用的字节,则返回-1。在输入数据可用、检测到流末尾或者抛出异常前,此方法一直阻塞。
read(byte[] b) : 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞。
如果 b 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;否则,至少读取一个字节并将其存储在 b 中。
将读取的第一个字节存储在元素 b[0] 中,下一个存储在 b[1] 中,依次类推。读取的字节数最多等于b 的长度。设 k 为实际读取的字节数;这些字节将存储在 b[0] 到 b[k-1] 的元素中,不影响 b[k] 到b[b.length-1] 的元素。
由帮助文档中的解释可知,read()方法每次只能读取一个字节,所以也只能读取由ASCII码范围内的一些字符。这些字符主要用于显示现代英语和其他西欧语言。而对于汉字等unicode中的字符则不能正常读取。只能以乱码的形式显示。
对于read()方法的上述缺点,在read(byte[] b)中则得到了解决,就拿汉字来举例,一个汉字占有两个字节,则可以把参数数组b定义为大小为2的数组即可正常读取汉字了。当然b也可以定义为更大,比如如果b=new byte[4]的话,则每次可以读取两个汉字字符了,但是需要注意的是,如果此处定义b 的大小为3或7等奇数,则对于全是汉字的一篇文档则不能全部正常读写了。
5、 流操作的步骤是什么?
流操作的步骤:
建立流
操作流
关闭流
6、 当做流操作时,如果文件不存在,会有什么样的结果?
操作文件流时,如果文件不存在,那么读取流会抛出Java.ioFileNotFoundException。
写入流会创建新文件(但前提必须有目录存在).