• 【IO流】FileInputStream FileOutputStream BufferInputStream BufferOutputStream


     FileInputStream

    • IO流用来处理设备之间的数据传输。
    • Java对数据的操作是通过流的方式。
    • Java用于操作流的类都在IO包中。
    1. 流按流向分为两种:输入流,输出流。
    2. 流按操作类型分为两种:

          字节流 : 字节流可以操作任何数据,因为在计算机中任何数据都是以字节的形式存储的

          字符流 : 字符流只能操作纯字符数据,比较方便。

    IO流常用父类

       字节流的抽象父类: InputStream 、OutputStream

       字符流的抽象父类: Reader 、Writer

    IO程序书写规则  使用前,导入IO包中的类 使用时,进行IO异常处理

                     使用后,释放资源

    FileInputStream fis = new FileInputStream("xxx.txt");    //创建流对象
    FileInputStream fis = new FileInputStream("xxx.txt");    //创建流对象
    int b;
    while((b = fis.read()) != -1) {                //将每次读到的字节赋值给b并判断是否是-

    System.out.println(b); }
    fis.close();                             //关闭流

    read()方法读取的是一个字节,为什么返回是int,而不是byte?

     因为字节输入流可以操作任意类型的文件,比如图片音频等,这些文件底层都是以二进制形式的存储的,如果每次读取都返回byte,

    有可能在读到中间的时候遇到111111111,而11111111是byte类型的-1,我们的程序是遇到-1就会停止不读了,后面的数据就读不到了,

    所以在读取的时候用int类型接收,如果11111111会在其前面补上24个0凑足4个字节,

    那么byte类型的-1就变成int类型的255了这样可以保证整个数据读完,而结束标记的-1就是int类型

         * 00010100 00100100 01000001 11111111 0000000
         * 
         * 10000001    byte类型-1的原码
         * 11111110    -1的反码
         * 11111111    -1的补码
         * 
         * 00000000 00000000 00000000 11111111      //这是 int 类型的 255 

     FileOutputStream

  • 相关阅读:
    【转】RocketMQ事务消费和顺序消费详解
    RocketMQ初探(五)之RocketMQ4.2.6集群部署(单Master+双Master+2m+2s+async异步复制)
    Spring定时器Quartz的使用
    RocketMQ初探(四)之RocketMQ4.x版本可视化管理控制台rocketmq-console-ng搭建(Apache)
    RocketMQ入门(简介、特点)
    RocketMQ初探(二)之RocketMQ3.26版本搭建(含简单Demo测试案例)
    RocketMQ初探(一)
    tomcat详解
    HDFS读写流程
    RabbitMQ
  • 原文地址:https://www.cnblogs.com/gaoyang666/p/11346092.html
Copyright © 2020-2023  润新知