IO分类:
    按照数据流向分类:
        输入流
        
        输出流
    
    按照处理的单位划分:
        字节流:字节流读取的都是文件中的二进制数据,读取到的二进制数据不会经过任何处理
        
        字符流:字符流读取的数据都是以字符为单位的,字符流也是读取的文件的二进制数据,只不过会把这些二进制数据转换成我们能识别的字符
                字符流 =  字节流 + 解码

输入字节流:
------------------|InputStream  所有输入字节流的基类  抽象类
-----------|FileInputStream  读取文件数据的输入字节流  throws FileNotFoundException
       
FileInputStream中的一些方法:

构造方法:
    FileInputStream(File file)   通过打开一个到实际文件的连接来创建一个 FileInputStream,该文件通过文件系统中的 File 对象 file 指定。
    
    其中的一些方法:
    read() 从此输入流中读取一个数据字节,如果已到达文件末尾,则返回 -1。throws IOException

read(byte[] b)  throws IOException
        把读取的数据存储到字节数组中,并返回本次读取到字节数组中去的字节大小,如果一个也没有返回-1
        注意:
            1.这里的每次读取到字符数组中是采用覆盖的方式,也就是第一次如果读取到字符数组中的数据是aaa第二次只读取了bb,那么现在数组中的数据是bba。
            2.read(byte b[])方法实际上是调用了 read(byte b[], int off, int len)方法

read(byte[] b, int off, int len)   从此输入流中将最多 len 个字节的数据读入一个 byte 数组中。
    
    close() 关闭此文件输入流并释放与此流有关的所有系统资源  throws IOException

注意:
        当我们在创建通道的时候,也就是实例化FileInputStream的时候,里面的指针会指向0,当我们每读取一个数据字节指针都会加一
        
读取文件的步骤:
    
    1.找到目标文件
    2.建立数据通道
    3.读取文件
    4.关闭通道(释放资源)

建议把实例看了后再看这个(百度的):

java中字符a和数字97的关系:
    
        将一个字符常量放到一个字符变量中,实际是将该字符的相应的ASCII代码放到存储单元中。
        如‘a’的ASCII代码为十进制数97,c1='a',在内存中是以97的二进制01100001存储的。
        字符数据以ASCII码存储,它的存储形式就与整数的存储形式类似。这样使字符型数据和整型数据之间可以通用。
        字符数据只占一个字节,它只能存放0~255范围内的整数。 注意:java中的char范围是0-65535 这个可能随着电脑不同和操作系统不同而不同
    
    为什么无参的read()方法的返回值是int类型而不是byte?
    
        Java中的数字都是有符号数,假如我们用一个byte类型去接收流中的字节码的话,
        那么假如刚好字节流里的字节码是-1的反码,那这个时候,read()返回了一个-1,
        那我们怎么知道read()是到达了流的末端还是字节码就是-1呢。
        而假如我们使用int类型的c来接收这些字节码,就不会出现这样的问题,高位补零,
        接收到的字节码放在最低的八位上,这样就能保证这些字节码都是“正数”

下面是分别用read()方法和read(byte[] b)读取数据

注意:在效率上面来说使用缓冲数组也就是用read(byte[] b)读取数据效率要高很多

public class Demo1 {
public static void main(String[] args){ readFile1();
System.out.println("\n---------");
readFile2();
} //read(byte[] b) 把读取的数据存储到字节数组中,并返回本次读取到字节数组中去的字节大小,如果一个也没有返回-1
public static void readFile1(){
FileInputStream fileInputStream = null;
try {
//找到目标文件
File file = new File("D:\\新建文件夹 (2)\\a.txt");
//建立数据通道
fileInputStream = new FileInputStream(file);
//读取文件(因为一次只能都取一个数据字节所以我们要用循环读出所有内容)
int content = 0;
//条件:如果已到达文件末尾,read()会返回 -1
while((content = fileInputStream.read())!=-1) {
//我们读取的是一个ASCII码,所以我们要把它强转成我们能看得懂的字符
System.out.print((char)content);
}
}catch(IOException e){
//这里用了一个运行时异常包装我们IO异常(编译时异常)发送出去,这样就不会强制让调用者处理异常,使调用者更加灵活
throw new RuntimeException(e);
}finally {
//关闭通道(释放资源)
//为了确保上面出现异常后,资源不能被释放的情况,我们一般会把关闭资源写在finally块里面
try{
fileInputStream.close();
}catch(IOException e){
//这里也用了一个运行时异常包装我们IO异常(编译时异常)发送出去
throw new RuntimeException(e);
}
}
} //使用read(byte[] b)读取数据 :从此输入流中将最多 b.length 个字节的数据读入一个 byte数组中。如果没有那么返回-1
//注意:这里的每次读取到字符数组中是采用覆盖的方式,也就是第一次如果读取到字符数组中的数据是aaa
//第二次只读取了bb,那么现在数组中的数据是bba。
public static void readFile2(){
FileInputStream fileInputStream = null;
try {
//找到目标文件
File file = new File("D:\\新建文件夹 (2)\\a.txt");
//建立数据通道
fileInputStream = new FileInputStream(file);
//定义变量,存储本次读取的字节大小
int length = 0;
//读取文件(创建缓存数组,把读取到的数据存储到数组中)
//一般字符数组的大小是1024的倍数,这个跟计算机的处理单位有关,“理论”上来说字节数组越大效率越高
byte[] buf = new byte[1024];
//条件:如果已到达文件末尾,read()会返回 -1
while((length = fileInputStream.read(buf))!=-1) {
//把字符数组转换成字符串并输出
System.out.println(new String(buf,0,length));
//本次读取到字符数组的字节大小为
System.out.println("本次读取的数据的字节大小:"+length);
}
}catch(IOException e){
//这里用了一个运行时异常包装我们IO异常(编译时异常)发送出去,这样就不会强制让调用者处理异常,使调用者更加灵活
throw new RuntimeException(e);
}finally {
//关闭通道(释放资源)
//为了确保上面出现异常后,资源不能被释放的情况,我们一般会把关闭资源写在finally块里面
try{
fileInputStream.close();
}catch(IOException e){
//这里也用了一个运行时异常包装我们IO异常(编译时异常)发送出去
throw new RuntimeException(e);
}
} }
}

63. (FileInputStream)输入字节流的更多相关文章

  1. (16)IO流之输入字节流FileInputStream和输出字节流FielOutputStream

    IO流技术解决的问题:设备与设备之间的传输问题,内存-->硬盘,硬盘-->内存,等等 IO流技术 如果按照数据的流向划分可以划分为:输入流和输出流 输入输出的标准是以程序为参考物的,如果流 ...

  2. FileInputStream 读取文件数据的输入字节流

    package com.inputstream; /* File类: 用于描述一个文件或者文件夹的. 通过File对象我们可以读取文件或者文件夹的属性数据,如果我们需要读取文件的内容数据,那么我们需要 ...

  3. BufferedInputStream 缓冲输入字节流 -------上

    package com.BufferedInputStreamUse; import java.io.BufferedInputStream; import java.io.File; import ...

  4. java基础43 IO流技术(输入字节流/缓冲输入字节流)

    通过File对象可以读取文件或者文件夹的属性数据,如果要读取文件的内容数据,那么我们就要使用IO技术. 一.输入字节流 输入字节流的体系:  -------| InputStream:所有输入字节流的 ...

  5. FileInputStream(字节流)与fileReader(字符流) 的区别

    FileInputStream 类 1 ) FileInputStream 类介绍: 以字节为单位的流处理.字节序列:二进制数据.与编码无关,不存在乱码问题. FileInputStream 类的主要 ...

  6. Java之高级IO,Properties

    IO流(高级) 释放资源的标准代码 主要考虑的是在什么时候释放资源比较合适.而且在jdk1.7之前和之后是不同的. package com.wzlove.demo; import java.io.Fi ...

  7. java:IO流(File,字节流/输入输出流(InputStream(FileInputStream),OutputStream(FileOutStream)),字符流(Reader,Writer))

    File: * java.io.File类:代表一个文件或目录. * 常用的构造方法: * File(String pathname)通过将给定路径名字符串转换为抽象路径名来创建一个新 File 实例 ...

  8. IO流输入 输出流 字符字节流

    一.流 1.流的概念 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直观的进行数据操作. ...

  9. Java IO 之 FileInputStream & FileOutputStream源码分析

    Writer      :BYSocket(泥沙砖瓦浆木匠) 微         博:BYSocket 豆         瓣:BYSocket FaceBook:BYSocket Twitter   ...

随机推荐

  1. tomcat如何正确的开启远程调试功能(转)

    转自:http://blog.csdn.net/mhmyqn/article/details/49209541 版权声明:本文为博主原创文章,未经博主允许不得转载. 在日常开发中,有时需要对远程服务器 ...

  2. java 逻辑运算符

    /* 与(并且) && 全部是true 否则就是false 或(或者) ||至少有一个是true ,就是true 全部是false 才是faalse 非(取反) ! 本来是true,变 ...

  3. Git中.gitignore文件不起作用

    Git中.gitignore文件不起作用的解决以及Git中的忽略规则介绍   在Studio里使用Git管理代码的过程中,可以修改.gitignore文件中的标示的方法来忽略开发者想忽略掉的文件或目录 ...

  4. django 在保存数据前进行数据校验

    我们想在保存用户进入数据库之前做一些字段的校验,先贴出代码: import re from django.db import models from django.db.models.signals ...

  5. poj 2104 无修改主席树

    题目大意: 求序列的区间第k大 基本思路: 因为我根本就没有思路,知道这是主席树,我就去学了下,在b站上看了uestc的教学视频,然后看了一篇博客,博客http://www.cnblogs.com/E ...

  6. 简单的51单片机多任务操作系统(C51)

    在网上看到这段代码,所以自己尝试了,可以跑起来,但是没有精确的定时功能,仅仅是任务的调度而已. 数组中是11,而不是12.这里写错了... /* 简单的多任务操作系统 其实只有个任务调度切换,把说它是 ...

  7. SSH出错

    [root@node01 ~]# ssh node02 ssh_exchange_identification: Connection closed by remote host 修改连接数无效 [r ...

  8. 【JVM】内存区域

    程序运行时,有六个地方都可以保存数据: 1. 寄存器:这是最快的保存区域,因为它位于和其他所有保存方式不同的地方:处理器内部.然而,寄存器的数量十分有限,所以寄存器是根据需要由编译器分配.我们对此没有 ...

  9. jdbc blob插入及查询操作

    首先建一张表 create table picture( picId ) primary key not null, picName ) not null, picfile image null ) ...

  10. location优先级

    location优先级 location优先级 location /img # 直接匹配 location /img { index index.html } location = /img # 精确 ...