InputStream.read([byte[]) 详解

InputStream.read([byte[]) 详解

一、一次读取文件字节流

1、ServletInputStream inputStream = request.getInputStream();
2、byte[] buffer = new byte[1024];
3、int read = inputStream.read(buffer);
4、System.out.println(read);
5、new String(buffer,0,read);
6、System.out.println(new String(buffer,0,read));

上传文件中的总体流程:文件->输入字节流->十进制整数(通过read(byte[])实现)
1、通过service方法的参数request获取文件输入字节流
2、定义了一个字节类型的数组,作为缓冲区,用于每次读取文件
3、inputStream.read(buffer)返回每次读取的长度,由于一开始文件较大每次读取的长度都等于数组的长度,直至最后一次
4、通过打印长度我们可以验证步骤3的正确性
5、读取buffer中的数据将其转化为字符串类型
6、打印5中获取的字符串
以上方法想要一次性的读取文件时,需要将缓冲区定义的足够大,因为没有设置循环

二、循环读取文件字节流
以下为需要读取的输入字节流:10个字节
InputStream.read([byte[]) 详解

 public static void main(String[] args) throws IOException {
        File file = new File("D:\\test.txt");
        byte[] b = new byte[4];
        InputStream in = new FileInputStream(file);
        int len = 0;
        while((len = in.read(b)) != -1){
            String str = new String(b);
            System.out.println(str);
            System.out.println(len);
        }
    }

以上程序相较于一,重点在于while((len = in.read(b)) != -1),判断每次读取的长度,当返回的长度等于-1代表已经全部读取输入字节流,程序的运行结果如下:
InputStream.read([byte[]) 详解
三、为了解决以上问题,可以修改为String str = new String(b,0,len);这行代码,代表每次读取从数组下标0开始,到下标为len-1未知

public static void main(String[] args) throws IOException {
        File file = new File("D:\\test.txt");
        byte[] b = new byte[4];
        InputStream in = new FileInputStream(file);
        int len = 0;
        while((len = in.read(b)) != -1){
            String str = new String(b,0,len);
            System.out.println(str);
            System.out.println(len);
        }
    }

菜鸟一只,如有不对之处请指出。您的鼓励是我写作的最大动力!

上一篇:根据网络url获取文件md5值 java


下一篇:JDK源码解析 InputStream类就使用了模板方法模式