java-IO流1(输入字节流)

来源:互联网 发布:eterm放大软件 编辑:程序博客网 时间:2024/05/19 14:53

IO流分类:

如果是按照数据的流向划分:

    输入流    输出流

判断使用输入流还是输出流的依据:以当前程序作为参照物观察数据是流入还是流出,如果数据流出则使用输出流,如果是数据流入,则使用输入流。

如果按照处理的单位划分:

字节流: 字节流读取得都是文件中二进制数据,读取到二进制数据不会经过任何的处理。

字符流: 字符流读取的数据是以字符为单位的 。 字符流也是读取文件中的二进制数据,不过会把这些二进制数据转换成我们能识别的字符。

字符流 = 字节流 + 解码

字节流分类:

输入字节流输出字节流

输入字节流:

——–| InputStream 所有输入字节流的基类 (抽象类)
————| FileInputStream 读取文件数据的输入字节流

注意:

何时使用字符流,何时使用字节流?依据是什么?

使用字符流的应用场景: 如果是读写字符数据的时候则使用字符流。

使用字节流的应用场景: 如果读写的数据都不需要转换成字符的时候,则使用字节流。

使用FileInputStream读取文件数据的步骤:

1. 找到目标文件。2. 建立数据的输入通道。3. 读取文件中的数据。4. 关闭资源。

FileInputStream案例:

public class Demo1 {    public static void main(String[] args) throws IOException {        readTest4();    }    //方式4:使用缓冲数组配合循环一起读取。(每次读取1024字节,速度快)28    public static void readTest4() throws IOException{        long startTime = System.currentTimeMillis();        //找到目标文件        File file = new File("F:\\美女\\1.jpg");        //建立数据的输入通道        FileInputStream fileInputStream = new FileInputStream(file);        //建立缓冲数组配合循环读取文件的数据。        int length = 0; //保存每次读取到的字节个数。        byte[] buf = new byte[1024]; //存储读取到的数据    缓冲数组 的长度一般是1024的倍数,因为与计算机的处理单位。  理论上缓冲数组越大,效率越高        while((length = fileInputStream.read(buf))!=-1){ // read方法如果读取到了文件的末尾,那么会返回-1表示。            System.out.print(new String(buf,0,length));        }        //关闭资源        fileInputStream.close();        long endTime = System.currentTimeMillis();        System.out.println("读取的时间是:"+ (endTime-startTime)); //446    }    //方式3:使用缓冲 数组 读取(每次读取1024字节,速度快)。    缺点: 无法读取完整一个文件的数据。     12G    public static void readTest3() throws IOException{        //找到目标文件        File file = new File("F:\\a.txt");        //建立数据的输入通道        FileInputStream fileInputStream = new FileInputStream(file);        //建立缓冲字节数组,读取文件的数据。        byte[] buf = new byte[1024];  //相当于超市里面的购物车。        int length = fileInputStream.read(buf); // 如果使用read读取数据传入字节数组,那么数据是存储到字节数组中的,而这时候read方法的返回值是表示的是本次读取了几个字节数据到字节数组中。        System.out.println("length:"+ length);        //使用字节数组构建字符串        String content = new String(buf,0,length);//从第0个到length个        System.out.println("内容:"+ content);        //关闭资源        fileInputStream.close();    }    //方式2 : 使用循环读取文件的数据    public static void readTest2() throws IOException{        long startTime = System.currentTimeMillis();        //找到目标文件        File file = new File("F:\\美女\\1.jpg");        //建立数据的输入通道        FileInputStream fileInputStream = new FileInputStream(file);        //读取文件的数据        int content = 0; //声明该变量用于存储读取到的数据        while((content = fileInputStream.read())!=-1){            System.out.print((char)content);        }        //关闭资源        fileInputStream.close();        long endTime = System.currentTimeMillis();        System.out.println("读取的时间是:"+ (endTime-startTime)); //446    }    //读取的方式一缺陷: 无法读取完整一个文件的数据.只能读取一个字节!    public static void readTest1() throws IOException{        //1. 找到目标文件        File file = new File("F:\\a.txt");        //建立数据的输入通道。        FileInputStream fileInputStream = new FileInputStream(file);        //读取文件中的数据        int content = fileInputStream.read(); // read() 只读取一个字节的数据,把读取的数据返回。        System.out.println("读到的内容是:"+ (char)content);//转换为char类型        //关闭资源    实际上就是释放资源。          fileInputStream.close();    }}
0 0