黑马程序员技术交流社区

标题: inputstream() 中的read()方法 不懂 [打印本页]

作者: 胡焱老师    时间: 2014-3-12 01:38
标题: inputstream() 中的read()方法 不懂
read()方法:从输入流读取下一个数据字节     没有用循环语句  !
怎么能读完这么多字节呀 ???

QQ截图20140312013448.jpg (133.42 KB, 下载次数: 13)

QQ截图20140312013448.jpg

作者: 胡焱老师    时间: 2014-3-12 01:41
补充                    

QQ截图20140312013944.jpg (85.83 KB, 下载次数: 13)

QQ截图20140312013944.jpg

作者: 周定宁    时间: 2014-3-12 08:54
read()与read(byte[] b)这两个方法在抽象类InputStream中前者是作为抽象方法存在的,后者不是,JDK API中是这样描述两者的:

1:read() :
从输入流中读取数据的下一个字节,返回0到255范围内的int字节值。如果因为已经到达流末尾而没有可用的字节,则返回-1。在输入数据可用、检测到流末尾或者抛出异常前,此方法一直阻塞。

2: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等奇数,则对于全是汉字的一篇文档则不能全部正常读写了。
作者: 段誉    时间: 2014-3-12 22:46
本帖最后由 段誉 于 2014-3-12 22:52 编辑

这是结合网络的 Socket 和 Client下的数据的储存!当socket联通时,由getinputStrean()去接受数据存在in,
再由in传给bety 数组【1024】代表数组的大小,一个字节, byte【】 又赋值给啦int 。因为java中一个int占4个字节。所以能装下利用in.read(byte[])
方法:
public int read(byte[] b),
从输入流中读取一定数量的字节,并将其存储在缓冲区数组 bute[] 中。
用String方法:
public String(byte[] bytes,int offset, int length)  来输出byte[]数组 从0。


创建一个1024byte的数组, 从输入流中读取1024的长度。 用string输出。





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2