IO 的read() 方法一般分2种情况:
1、字节流,的read()方法,如InputStream.read(),FileInputStream.read()等,从输入流中读取数据的下一个字节。
InputStream的read(byte[] b )方法:
read
public int read(byte[] b)
throws IOException从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞。
如果 b 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;否则,至少读取一个字节并将其存储在 b 中。
将读取的第一个字节存储在元素 b[0] 中,下一个存储在 b[1] 中,依次类推。读取的字节数最多等于 b 的长度。设 k 为实际读取的字节数;这些字节将存储在 b[0] 到 b[k-1] 的元素中,不影响 b[k] 到 b[b.length-1] 的元素。
类 InputStream 的 read(b) 方法的效果等同于:
read(b, 0, b.length)
参数:
b - 存储读入数据的缓冲区。
返回:
读入缓冲区的总字节数;如果因为已经到达流末尾而不再有数据可用,则返回 -1。
抛出:
IOException - 如果不是因为流位于文件末尾而无法读取第一个字节;如果输入流已关闭;如果发生其他 I/O 错误。
NullPointerException - 如果 b 为 null
2、字符流,如Reader的read()方法,读取单个字符。一个字符相当于2个字节。
下面是Reader的方法read(char[] cbuf)
read
public int read(char[] cbuf)
throws IOException将字符读入数组。在某个输入可用、发生 I/O 错误或者已到达流的末尾前,此方法一直阻塞。
参数:
cbuf - 目标缓冲区
返回:
读取的字符数,如果已到达流的末尾,则返回 -1
抛出:
IOException - 如果发生 I/O 错误
------------------------------------这段代码只为验证InputStream的read()方法的返回值。如果文件没内容或者内容读完就是-1,如果int len=reader.read(c);
童鞋的说法有误,InputStreamReader是InputStream的包装类,并不等同于InputStream。
InputStream是IO字节流,InputStreamReader是字符流,你在代码中的read(c)方法,读取的是字符,返回值len是,读取的字符数,如果已到达流的末尾,则返回 -1 。
System.out.println((char)len);
出现乱码是因为强制把int类型装换为char类型时有错误。
int--------->char 用到ASCII编码值。26个字母(char)对于26个int类型的数据,字母的大小写区分的。
System.out.println((char)97); ----输出结果为:a
当len在ASICC中找不到对应的字符时,转换就不成功。
[ 本帖最后由 覃俊瑞 于 2011-07-30 16:51 编辑 ] |