FileInputStream.read(byte[] b),数组长度大于读取内容字节数长度

在学习I/O数据流时学习了FileInputStream.read(byte[] b)方法,在使用这个方法时发现,当数组的长度大于读取内容字节数长度(字符、数字1字节、中文2字节、换行2字节)时,使用Arrays.toString(b)观察b数组的内容发现,b数组里有除读取内容外的其他内容。为此我做了测试。

package day20;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Arrays;

public class day20_21 {

public static void main(String[] args) throws IOException {
    // TODO 自动生成的方法存根   
    FileInputStream fis=new FileInputStream("无标题 1");
    byte[] b=new byte[2];

    //查看read方法返回值(读取到的内容字节长度)
    System.out.println(fis.read(b));
    //查看数组实际存储内容
    System.out.println(Arrays.toString(b));
    //第二次查看read方法返回值(读取到的内容字节长度)
    System.out.println(fis.read(b));
    //第二次查看数组实际存储内容
    System.out.println(Arrays.toString(b));
}

}

“无标题 1”文件内容:只有012三个数字
FileInputStream.read(byte[] b),数组长度大于读取内容字节数长度_第1张图片

程序运行结果:
这里写图片描述

分析:由于数组只有2个字节,而文件有3个字节,所以需要两次read()才能全部读完,第一次数组内容正确,第二次理论上应该只读取到了50(ASCII表表示2),但是他读取到了50和49(ASCII表表示2和1),由此我发现了问题的关键,read()采用的是覆盖存储,当b数组第一次存储了48、49,第二次存储50时就自动把48覆盖49不管他,所以看到的就是read()返回1但是数组实际内容却有两个字节。

你可能感兴趣的:(java浅学)