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让文件读取的时候还没到末尾提前结束读取吗?答案是不能的,具体看如下代码:
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(); } }