字节流-输入字节流-FileInputStream

本文详细介绍了Java中的FileInputStream类,包括其构造方法、异常处理及如何使用read方法读取文件内容。通过示例代码展示了如何创建FileInputStream实例并读取文件。

FileInputStream 文件字节输入流,常用于从系统上读取数据,以字节的方式。它继承了 InputStream 类,InputStream是字节输入流的抽象类。
FileInputStream 常用的构造方法,它们都抛出一个FileNotFoundException的异常,当文件路径不正确的时候会触发。这个在编码的时候要处理掉,使用自定义异常来处理,不能直接往外抛。
FileInputStream(String name):该方法传入一个字符串类型的参数,要读取文件的绝对路径。

    public FileInputStream(String name) throws FileNotFoundException {
        this(name != null ? new File(name) : null);
    }

示例:

InputStream is = new FileInputStream("e:/app/f.txt");

FileInputStream(File file):该方法传入一个file类型的数据。

    public FileInputStream(File file) throws FileNotFoundException {
        String name = (file != null ? file.getPath() : null);
        SecurityManager security = System.getSecurityManager();
        if (security != null) {
            security.checkRead(name);
        }
        if (name == null) {
            throw new NullPointerException();
        }
        fd = new FileDescriptor();
        fd.incrementAndGetUseCount();
        open(name);
    }

示例:

        File file = new File("e:/app/f.txt");
        InputStream ins = new FileInputStream(file);

FileInputStream 的常用方法,read方法,它有几个重载,int readBytes(byte b[], int off, int len) 是基础,它是native 方法。read(byte b[]) 方法调用了 int readBytes(byte b[], int off, int len) 方法。read方法返回一个-1表示还没有读取结束,常将它的结果3和人-1比较,不等于-1继续读取。
操作完成后要释放资源,掉用 close() 方法,关闭流。

看下面一个例子,该示例使用FileInputStream 读取文件中的内容,并在控制台上打印出来。
该示例中使用了 FileInputStream 的 read(byte [] b) 方法,为了避免浪费内存,该数据的大小根据要读取文件的大小来指定。

package cmc.com.jer.cmc;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;

public class Demo3 {

    public static void main(String[] args) {
        // 声明 file 
        File file = new File("e:/app/f.txt");
        // 这个数组的大小根据文件来指定,避免内存浪费 ,该数组用来存储读取的字节
        byte [] b = new byte[(int)file.length()];
        // 字节输入流  FileInputStream
        InputStream in =null;
        try {
             in = new FileInputStream(file);
                try {
                    //把读取到的字节新放入 数组 b中
                    in.read(b);
                    System.out.println(new String(b));
                } catch (IOException e) {
                    e.printStackTrace();
                } finally {
                    if(in !=null){
                        try {
                            in.close();
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                    }
                }

        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }

    }
}
### Java 字节流输入输出示例 #### 使用 `ByteArrayInputStream` 和 `ByteArrayOutputStream` 下面展示如何利用 `ByteArrayInputStream` 从字节数组中读取数据以及通过 `ByteArrayOutputStream` 向字节数组写入数据。 ```java import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; public class ByteStreamExample { public static void main(String[] args) throws IOException { // 定义要处理的数据 byte[] inputBytes = {1, -1, 25, -22, -5, 23}; /// 创建 ByteArrayInputStream 对象用于读取字节数组中的数据 ByteArrayInputStream bais = new ByteArrayInputStream(inputBytes); int readByte; System.out.println("Reading from ByteArrayInputStream:"); while ((readByte = bais.read()) != -1) { System.out.println("Original Value=" + (byte) readByte + " \tConverted to Int=" + readByte); } bais.close(); // 准备一些新数据准备写入 ByteArrayOutputStream 中 byte[] outputData = {-7, 9, 8, 4, 0, 6}; ByteArrayOutputStream baos = new ByteArrayOutputStream(); for (byte data : outputData) { baos.write(data); // 写入单个字节 } // 获取写出后的全部字节内容 byte[] writtenBytes = baos.toByteArray(); System.out.println("\nWriting into and reading back from ByteArrayOutputStream:"); for (byte aByte : writtenBytes) { System.out.print(aByte + " "); } baos.close(); } } ``` 上述程序展示了两个主要部分:首先是创建了一个 `ByteArrayInputStream` 来模拟从内存中的字节数组读取;其次是使用了 `ByteArrayOutputStream` 来向另一个字节数组写入数据[^1]。 对于更复杂的场景,比如文件操作,可以采用类似的模式但是替换为相应的文件流对象如 `FileInputStream` 或者 `FileOutputStream` 进行实际磁盘上的文件读写操作[^2]。 当涉及到大量数据传输时,通常会考虑批量读写的效率问题,这时就可以借助于带有缓冲区的方式或是直接调用支持批量处理的方法来提高性能[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值