慎用InputStream的read()方法
?
????????? InputStream此抽象类是表示字节输入流的所有类的超类。
????????? 我们从输入流中读取数据最常用的方法基本上就是如下3个read()方法了:
???????? 1、 read()方法,这个方法从输入流中读取数据的下一个字节。返回 0 到 255 范围内的 int 字节值。如果因为已经到达流末尾而没有可用的字节,则返回值 -1。
???????? 2、read(byte[]?b,int?off,int?len)方法,将输入流中最多 len 个数据字节读入 byte 数组。尝试读取len 个字节,但读取的字节也可能小于该值。以整数形式返回实际读取的字节数。
???????? 3、read(byte[]?b)方法,从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。
???????? 第一个方法典型的确定就是处理效率低,不是某些特殊情况,很少使用它,下面说说第2个方法跟第3个方法,第3个方法的本本质其实就是第2个方法的特殊情况,效果等同于:
???????? read(b, 0,b.length)
所以这里把他们放着一起讨论。
???????? 从第2个方法的API文档说明来看:“将输入流中最多len 个数据字节读入 byte 数组。尝试读取len 个字节,但读取的字节也可能小于该值。以整数形式返回实际读取的字节数。”,最多读取len个字节,这究竟是何意?API文档并没有详细说明。是不是就意味着有可能(注意这里是有可能而不是一定,)读取不到len个字节呢?答案是“是的”。虽然造成这种情况的原因是什么个人并不知道,但是我们可以通过例子来发现这种情况,下面是源代码(由于只是简单的示例,所以代码也就随便写了):
?
ServerSocket端:
?
?
Socket端:
?
int readBytes=0;Byte[] b=new byte[1024]//1024可改成任何需要的值int len=b.length;while (readBytes < len) { int read = is.read(b, readBytes, len - readBytes); //判断是不是读到了数据流的末尾 ,防止出现死循环。 if (read == -1) { break; } readBytes += read; }