关于java字节流类的read()方法返回值为int的思考

今天群里的小伙伴问了一个问题:为什么字节流类的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的原因,为了转换方便吧。

猜你喜欢

转载自blog.csdn.net/qq_20492999/article/details/81222075