日期:2014-05-20  浏览次数:20877 次

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


------解决方案--------------------
楼主看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。
------解决方案--------------------
int len = mm.read (cc)
int返回值表示实际读入的字节数,比如文件有20个字节,但你用byte[32]数组去读,那么实际只读如20个字节,也就是返回值是20,这样用户就知道byte[32]数组的前20个元素有数据,后12个元素没数据

至于read的原理,那就只能看源码了,估计是封装C的fread之类的
------解决方案--------------------
楼上说的都对。

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