byte buffer[] = new byte[10240];
socket.getInputStream().read(buffer);
上面这段程序因为初始化的时候buffer[]就全是0了,这样等读完socket以后,就不知道从socket里面实际读了多少数据
请高手们帮忙

解决方案 »

  1.   

    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。 read方法会有返回值 返回它读取了多少字节
      

  2.   

    byte buffer[] = new byte[要读数据的大小];byte buffer[] = new byte[10240]; 设小点 
      

  3.   

    read(byte[] b)方法不是有返回值吗?返回值就是读取的字节数
      

  4.   

    read()方法的返回值就是你读入的字节数
      

  5.   

    byte buffer[] = new byte[10240]; 
    InputStream is = socket.getInputStream()
    int len = is.read(buffer); 
    //len即为本次read从IO中读取的有效字节数。
    //当len为-1时,说明已经读到IO的末尾。(有可能对方将OutputStream给close掉了。
    //当len为buffer.length时,说明本次读取的数据已经将缓冲区全部填满。(有可能IO中还有数据)
      

  6.   

    还有,刚才的read方法是阻塞读。当对方没有将buffer填满或者close掉对方的OutputStream时,调用read的线程是阻塞状态的,
    直到Socket超时抛出异常后,程序才会有反应。