关于java.io包中,FileInputStream 的read()方法
API文档说“Readsthenextbyteofdatafromthisinputstream.”,但为什么返回值是int类型?返回的字节为什么要以int表示?...
API文档说“Reads the next byte of data from this input stream.”,但为什么返回值是int类型?
返回的字节为什么要以int表示? 展开
返回的字节为什么要以int表示? 展开
展开全部
API说明:
public int read() throws IOException
从此输入流中读取一个数据字节。如果没有输入可用,则此方法将阻塞。
指定者:类 InputStream 中的 read
返回:下一个数据字节;如果已到达文件末尾,则返回 -1。
抛出:IOException - 如果发生 I/O 错误。
个人理解:
该方法将输入按字节读入,当读取到字节时就返回该字节的int型数值(可以将其强制转换成byte类型),如果读取到文件末尾也就是无数据可读时则返回-1,表示以读到文件末尾。顺便说一句按此方法读取时需要将读到的int转成byte同时存入到一个足够大的byte数组中,然后根据该数组构造字符串,显示结果!
例:
public static void main(String[] args) throws IOException {
File f = new File("E:/java文件/demo1.txt");
InputStream ins = new FileInputStream(f);
byte[] bb = new byte[1024];
int temp = 0;
int i = 0;
while ((temp = ins.read()) != -1) {
bb[i++] = (byte) temp;
System.out.println((byte) temp);
}
System.out.println(new String(bb, "UTF-8").trim());
}
关于Byte的toString()方法:
返回表示此 Byte 的值的 String 对象。该值被转换成有符号的十进制表示形式,并作为一个 string 返回,正如将 byte 值作为一个参数指定给 toString(byte) 方法所返回的一样。
覆盖:类 Object 中的 toString
返回:以基数 10 表示的此对象值的字符串表示形式。
public int read() throws IOException
从此输入流中读取一个数据字节。如果没有输入可用,则此方法将阻塞。
指定者:类 InputStream 中的 read
返回:下一个数据字节;如果已到达文件末尾,则返回 -1。
抛出:IOException - 如果发生 I/O 错误。
个人理解:
该方法将输入按字节读入,当读取到字节时就返回该字节的int型数值(可以将其强制转换成byte类型),如果读取到文件末尾也就是无数据可读时则返回-1,表示以读到文件末尾。顺便说一句按此方法读取时需要将读到的int转成byte同时存入到一个足够大的byte数组中,然后根据该数组构造字符串,显示结果!
例:
public static void main(String[] args) throws IOException {
File f = new File("E:/java文件/demo1.txt");
InputStream ins = new FileInputStream(f);
byte[] bb = new byte[1024];
int temp = 0;
int i = 0;
while ((temp = ins.read()) != -1) {
bb[i++] = (byte) temp;
System.out.println((byte) temp);
}
System.out.println(new String(bb, "UTF-8").trim());
}
关于Byte的toString()方法:
返回表示此 Byte 的值的 String 对象。该值被转换成有符号的十进制表示形式,并作为一个 string 返回,正如将 byte 值作为一个参数指定给 toString(byte) 方法所返回的一样。
覆盖:类 Object 中的 toString
返回:以基数 10 表示的此对象值的字符串表示形式。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询