A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 黄新灵 黑马帝   /  2011-10-8 10:59  /  2021 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

字节流:InputStream / OutputStream
public abstract int read() throws IOException
从输入流读取下一个数据字节。返回 0 到 255 范围内的 int 字节值。如果因已到达流末尾而没有可用的字节,则返回值 -1
为什么读的是数据字节而返回的却是int不是byteread()内部是怎样转换的???

评分

参与人数 1技术分 +1 收起 理由
wangfayin + 1

查看全部评分

2 个回复

倒序浏览
本帖最后由 刘洋 于 2011-10-8 11:09 编辑

public abstract int read() throws IOException返回值是下一个数据字节;如果到达流的末尾,则返回 -1。
但是子类必须提供此方法的一个实现。
你可以用已经实现的方法
public int read(byte[] b)  throws IOException返回值是读入缓冲区的总字节数;如果因为已经到达流末尾而不再有数据可用,则返回 -1。
或者public int read(byte[] b, int off, int len)  throws IOException

评分

参与人数 1技术分 +1 收起 理由
wangfayin + 1 赞一个!

查看全部评分

回复 使用道具 举报
read()返回的不是整型,不过在实现应用中会强制转换成byte类型,但在转换的过程中,会丢弃前三个字节所补的零,最终得到从流中读取的真实的编码,这种方法不适合读取非字符文件。
read(byte[])这个方法就增强了read()这个方法,可以读取任意文件而不会丢失字节。

评分

参与人数 1技术分 +1 收起 理由
wangfayin + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马