java中read()方法的原理是什么?

Python011

java中read()方法的原理是什么?,第1张

既然你能看到这个方法的源代码,那你也应该能看到FilterInputStream类的其它方法的源代码,FilterInputStream类中有十个方法和一个InputStream类型的变量,变量名是in。

十个方法里有九个是重写InputStream类的方法,并且八个是直接调用变量in的同名同参方法,另一个也只是在调用in的方法时填了两个默认参数。

而十个方法中的另一个方法是构造方法,参数是InputStream的,在方法中,直接把这个参数赋给了变量in。

所以FilterInputStream实质上只是对InputStream类做了一个简单的封装,实际调用的方法是在构造方法里传过来的InputStream对象的方法。

所以想看read()方法的具体实现,应给去找InputStream类或InputStream类的子类

java使用read()方法进行读文件中的四个字节保存在数组总的示例如下:

public static void main(String[] arg) throws Exception {

BufferedReader reader = new BufferedReader(new FileReader("E:/test.txt"))

int[] list = new int[20]

int i = 0

String line = null

while ((line = reader.readLine()) != null) {

String[] vStrs = line.split(" ")

for (String str : vStrs) {

list[i++] = Integer.parseInt(str)

}

}

System.out.println(Arrays.toString(list))

}

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 表示的此对象值的字符串表示形式。