我学到了流方面的知识有个地方很不解就是用read()方法是返回一个int型数据,这个int型数据是表示什么的???
比如int len = mm.read (cc),求大神讲解read()方法的内部原理,谢谢

解决方案 »

  1.   

    楼主看api吧,上面都写着。如果要看具体实现,可以看下源码。不过,刚开始学,也用不着看那么细的。
    下面是摘自中文api文档。从输入流中读取一定数量的字节,并将其存储在缓冲区数组 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。
      

  2.   

    int len = mm.read (cc)
    int返回值表示实际读入的字节数,比如文件有20个字节,但你用byte[32]数组去读,那么实际只读如20个字节,也就是返回值是20,这样用户就知道byte[32]数组的前20个元素有数据,后12个元素没数据至于read的原理,那就只能看源码了,估计是封装C的fread之类的
      

  3.   

    楼上说的都对。内部原理的话只能去看源码了。
    我都不看API,直接源码。