byte buffer[] = new byte[10240];
socket.getInputStream().read(buffer);
上面这段程序因为初始化的时候buffer[]就全是0了,这样等读完socket以后,就不知道从socket里面实际读了多少数据
请高手们帮忙
socket.getInputStream().read(buffer);
上面这段程序因为初始化的时候buffer[]就全是0了,这样等读完socket以后,就不知道从socket里面实际读了多少数据
请高手们帮忙
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。 read方法会有返回值 返回它读取了多少字节
InputStream is = socket.getInputStream()
int len = is.read(buffer);
//len即为本次read从IO中读取的有效字节数。
//当len为-1时,说明已经读到IO的末尾。(有可能对方将OutputStream给close掉了。
//当len为buffer.length时,说明本次读取的数据已经将缓冲区全部填满。(有可能IO中还有数据)
直到Socket超时抛出异常后,程序才会有反应。