InputStream就是Java标准库提供的最基本的输入流。它位于java.io这个包里。java.io包提供了所有同步IO的功能。
要特别注意的一点是,InputStream并不是一个接口,而是一个抽象类,它是所有输入流的超类。这个抽象类定义的一个最重要的方法就是int read(),起方法在源码中定义如下:
我们如下以FileInputStream类为例,来结束read()方法,在FileInputStream类中,read()方法调用了read0()方法,而read0()方法才是我们标题中提到的native方法,包括其他的实现类,也基本上都是这样去实现的,这里只以FileInputStream为例,其他的类都类似。
如下为FileInputStream类中read()和read0()方法:
这个方法会读取输入流的下一个字节,并返回字节表示的int值(0~255)。如果已读到末尾,返回-1表示不能继续读取了。
进入正题,那么我们可以人为的从去输入-1让文件读取的时候还没到末尾提前结束读取吗?答案是不能的,
虽然写入的时候是以byte形式写的,但是读出的时候是以int形式读的
比如:写的时候(byte)0b11111111,byte类型应该为-1,但是读的时候却是以int类型去读,会在前面自动补0,
也就是说读的时候,读取到的是(int)ob00000000_00000000_00000000_11111111;
所以说我们人为基本上是不能能输入为-1的情况,也就是文件读取结束的情况
具体看如下代码:
public class ReadDemo {
public void readFile() throws IOException {
FileOutputStream fileOutputStream = new FileOutputStream("src/com/ysw/demo02IO/readtest.txt");
/**
* byte共有8个比特位,
* 其中最高位是符号位,
* 给它赋值0b1111_1111时,
* 最高位的1系统无法判断是实际数值还是符号位数值。
* 添加强制类型转换(byte),则系统可以知道1是符号位,
* 此时可以被赋值;如果没有加强制类型转换,则系统认为0b1001_0101是一个int类型数据。
* int类型值无法赋值给byte变量,所以会报错。
* */
byte[] a = {
0x30,0x31,0x32,(byte)0b11111111,0x30,0x31,0x32};
fileOutputStream.write(a);
// 创建一个FileInputStream对象:
InputStream input = new FileInputStream("src/com/ysw/demo02IO/readtest.txt");
for (;;) {
/**
* 虽然写是以byte形式写的,但是读的时候是以int形式读的
* 比如:写的时候(byte)0b11111111,byte类型应该为-1,但是读的时候却是以int类型去读,会在前面自动补0,
* 也就是说读的时候,读取到的是(int)ob00000000_00000000_00000000_11111111;
* 所以说我们人为基本上是不能能输入为-1的情况,也就是文件读取结束的情况
* */
int n = input.read(); // 反复调用read()方法,直到返回-1
if (n == -1) {
break;
}
System.out.println(n); // 打印byte的值
}
input.close(); // 关闭流
fileOutputStream.close();
}
public static void main(String[] args) throws IOException {
new ReadDemo().readFile();
}
}