今天群里的小伙伴问了一个问题:为什么字节流类的read()方法返回值为int?
带着问题我去看了一下源码。但是源码中并没有详细的代码,只有private native int read0() throws IOException;
对于这个问题,可能不是很重要,但是很多开发者也没有注意到,但是技多不压身,利人利己吧。
网上搜索了一些资料,大概得出范围值类型为int的理由:
read0方法由native修饰,普及一下native的作用:
native是一个计算机函数,一个Native Method就是一个Java调用非Java代码的接口。方法的实现由非Java语言实现,比如C或C++。
我们都知道Java语言底层是由C语言实现的,在C语言中的字节用unsigned byte基本数据类型,但是在Java中没有这个类型。
unsigned byte的取值范围是无符号 0-255
,能表示所有的字节。
而Java中的byte的取值范围为有符号 -128-127
。
但这里会有一个问题:我们如何去判断已经读取到文件最后的字节,也就是如何告诉程序该结束流
聪明的开发者发现byte并不能满足我们的需求。
所以要考虑如何找一个类型代替,所以就用了int来代替,用-1表示读到最后字节,0-255表示字节。
使用-128 & 0xff = 128
-127 & 0xff = 129
-1 & 0xff = 255
就把byte提升为int类型了,来表示数据。
或许这是用int而不用short的原因,为了转换方便吧。