十个方法里有九个是重写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 表示的此对象值的字符串表示形式。