• FileChannel 文件流的简单使用


    FileChannel

    注意: FileChannel 只能工作在阻塞模式下
    复制代码
    
    • 1
    • 2

    新建

    FileChannel 是一个抽象类, 所以不能直接创建对象

    创建一个 FileChannel 有以下三种方式:

    • 创建一个 FileInputStream 对象, 但是该对象获取到的 Channel 只能读取
    • 创建一个 FileOutputStream 对象, 但是该对象获取到的 Channel 只能写入
    • 创建一个 RandomAccessFile 对象, 该对象能否读写是根据构造 RandomAccessFile 时设置的读写模式设定的

    注意: Channel 使用之后必须关闭
    不主动 close 并且 未触发gc , 那么 连接句柄 将被 一直占用, 如果此时使用的是连接池方式, 将造成连接池中的连接不能及时的被回收问题

    在调用 FileInputStream 、 FileOutputStream 和 RandomAccessFile 的 close 方法会间接调用 Channel 的 close 方法

    实现文件的读写

    通过以下代码可以简单的通过 FileInputStream 和 FileOutputStream 来实现对文件的读写

    但是这里有个问题, FileChannel 的 transferTo 只能传输 2G 以内的数据, 超过 2G 就传输不了了,

    下面是 FileChannel 的 tarnsferTo 方法, 可以看到他是存在返回值的, 这个返回值就代表着还剩下多少字节的内容没有进行传输, 所以我们可以使用一个 for 循环来对当前的代码进行改进

    改进后的代码如下所示

    本篇文章所有代码

    public static void main(String[] args) {
        try(
                FileChannel inputChannel = new FileInputStream("test1.txt").getChannel();
                FileChannel outputChannel = new FileOutputStream("test2.txt").getChannel()
        ){
            // 获取到 输入流 的大小
            long size = inputChannel.size();
            // res 代表剩余多少字节没有进行传输
            for (long res = size; res > 0; ){
                // 将 inputChannel 流读取到的内容通过 outputChannel 传输到指定的地址
                // 效率高, 底层会利用操作系统的 零拷贝 进行优化, 但是一次只能传输 2G 的数据
                // 该方法返回值为 剩余未传输的 字节数
                res = inputChannel.transferTo(0, inputChannel.size(), outputChannel);
            }
        }catch (Exception e){
            e.printStackTrace();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
  • 相关阅读:
    存储模型:大端和小端
    JTAG介绍
    【精品】pinia详解
    初识Spring框架及其特点
    [前端]NVM管理器安装、nodejs、npm、yarn配置
    英语读书笔记-Book Lovers Day 09
    CSS3新增特性(一)
    Linux目录结构和系统指令
    Java的浅拷贝与深拷贝
    431. 将 N 叉树编码为二叉树 DFS
  • 原文地址:https://blog.csdn.net/Huangjiazhen711/article/details/127817355