【Java NIO 简例】FileChannel 数据传输

Java NIO的FileChannel提供了transferFrom和transferTo方法,用于高效地读取或写入文件。这两个方法避免了传统的循环读写,允许直接在Channel之间传输数据,利用操作系统的直接内存拷贝,提高性能。transferFrom从ReadableByteChannel读取数据写入FileChannel,而transferTo则从FileChannel读取数据写入WritableByteChannel。当可用数据量小于指定数量时,只会传输实际可用的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:《Java NIO Channel to Channel Transfers

 

FileChannel 的 transferFrom 和 transferTo 方法可以方便地将数据传入 FileChannel(写文件)或 读取 FileChannel 中的数据(读文件)

这两个方法比简单的 循环 读取-写入 更高效。因为许多操作系统能直接将 源Channel 中的数据传输到 文件系统缓存中,而无需真正地复制这些数据。

transferFrom

该方法可以读取一个 ReadableByteChannel 中的数据,并传入 FileChannel。

Java代码

 

  1. FileChannel fromChannel = new RandomAccessFile("from.txt", "r").getChannel();  

  2. FileChannel toChannel = new RandomAccessFile("to.txt", "rw").getChannel();  

  3. long position = 0;  

  4. long count = fromChannel.size();  

  5. toChannel.transferFrom(fromChannel, position, count);  

如果 fromChannel 当前可提供的数据量小于指定的数据量(count),则只传输这些可提供的数据。

如 fromChannel 是 SocketChannel,只有当前就绪的数据会被传输到 toChannel,即使后续有更多数据进入 fromChannel。

 

transferTo

该方法可以读取 FileChannel 中的数据,并传入一个 WritableByteChannel。

Java代码

 

  1. FileChannel fromChannel = new RandomAccessFile("from.txt", "r").getChannel();  

  2. FileChannel toChannel = new RandomAccessFile("to.txt", "rw").getChannel();  

  3. long position = 0;  

  4. long count = fromChannel.size();  

  5. fromChannel.transferTo(position, count, toChannel);  

该方法与 transferFrom 相似,调换了 fromChannel 与 toChannel

与 transferFrom 一样,如果 fromChannel 当前可提供的数据量小于指定的数据量(count),则只传输这些可提供的数据。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值