`

Java nio篇 内存映射文件

阅读更多

Java读写小于2G的文件,可以采用内存映射文件方式。MappedByteBuffer是一种特殊类型的直接缓冲器,使用它我们必须制定映射文件的初始位置和映射区域的长度。

下面以读写1G的文件为例,简单地去应用一下直接缓冲器

// 2G以内的文件读写
// 创建读取文件通道
FileChannel rfc = new FileInputStream("E:/nio/test.dat").getChannel();
// 创建写文件通道
FileChannel wfc = new RandomAccessFile("E:/nio/my.dat", "rw").getChannel();
// 创建写文件直接缓冲器 此时写通道wfc.size()是0 此时要使用rfc.size()作为映射区域长度
MappedByteBuffer wb = wfc
		.map(FileChannel.MapMode.READ_WRITE, 0, rfc.size());
// 使用读取文件直接缓冲器rfc.size() 不能超过2G 没有测试 《Think in java》上写的阈值
MappedByteBuffer rb = rfc.map(FileChannel.MapMode.READ_ONLY, 0, rfc.size());
while (rb.hasRemaining()) {
	wb.put(rb.get());
}
rb.clear();
wb.clear();
rfc.close();
wfc.close();
System.out.println("读取完毕");

 

分享到:
评论

相关推荐

    Java NIO 应用使用内存映射文件实现进程间通信

    在Java NIO中,内存映射文件(MappedByteBuffer)是一个重要的特性,它允许将文件直接映射到内存中,以便于快速访问和修改文件内容。这一特性不仅提高了读写效率,而且还能用于进程间通信(IPC)。 内存映射文件的...

    java nio 包读取超大数据文件

    ### Java NIO 处理超大数据文件的知识点详解 ...综上所述,使用Java NIO处理超大数据文件时,关键是利用好内存映射文件技术和合理的数据读取策略,通过适当的分块和数据解析方法,可以有效地提升读取速度和处理能力。

    java nio 写文件

    Java NIO还提供了一种叫做内存映射文件的高级特性。通过`FileChannel.map()`方法,可以直接将文件映射到内存中,这样读写文件就像操作内存一样快速。但需要注意的是,内存映射文件可能会消耗大量内存,因此对于大...

    java NIO实例

    4. **FileChannel**:用于文件的读写,可以实现大文件的高效传输,支持内存映射(Mmap)技术,能直接将文件映射到内存中。 5. **SocketChannel**:用于网络通信,可以建立TCP连接,进行非阻塞的读写。在`NIOServer....

    java NIO.zip

    6. **内存映射文件(Memory-Mapped Files)**: NIO允许将文件直接映射到内存,使得读写文件就像操作普通缓冲区一样快速。通过MappedByteBuffer类,可以直接在内存中对文件进行操作,提高大文件处理的性能。 7. **...

    Large-File-Processing-master_javanio_java大文件处理_

    3. **内存映射文件(Memory-Mapped Files)**:Java NIO提供了一个特殊的功能,即内存映射文件,它可以将文件直接映射到内存中,使得文件操作如同访问内存一样快速。对于大文件处理,内存映射文件是一种高效的策略,...

    Java NIO英文高清原版

    4. **文件通道(File Channel)**:文件通道是直接与文件系统交互的通道,支持映射文件到内存(Memory-Mapped File)进行高速读写。 5. **网络通道(Network Channels)**:如SocketChannel和ServerSocketChannel,...

    java NIO 写文件

    4. **内存映射文件**:`MappedByteBuffer`允许将文件直接映射到内存,提供了极高的读写速度。 然而,尽管Java NIO提供了很多优势,但在实际使用中,开发者还需要注意一些潜在的问题,如内存管理(缓冲区过大可能...

    Java语言基础教程-Java NIO流篇2

    例如,FileChannel用于文件操作,它支持映射文件到内存(Memory-Mapped File)以提高读写速度;SocketChannel则用于网络通信,可以实现TCP连接的读写。 第5节会进一步深入,探讨通道的使用技巧和高级特性。这可能...

    Java NIO测试示例

    8. **内存映射文件(Memory-Mapped File)**: 使用MappedByteBuffer,NIO可以将文件映射到内存,使得文件操作如同操作内存一样快速,特别适合大数据处理。 在实际应用中,Java NIO通常用于高性能的服务器编程,...

    NIO与零拷贝_javanio_nio和零拷贝_

    - **mmap(Memory Mapped File)**:Java的FileChannel提供了一个映射文件到内存的功能。通过映射,文件数据可以直接被网络发送,跳过了从磁盘到用户空间再到内核空间的拷贝步骤。 - **Sendfile系统调用**:在...

    java 深入理解内存映射文件原理

    在Java中,使用内存映射文件通常通过java.nio包中的MappedByteBuffer类实现。通过FileChannel的map()方法,可以将文件映射到内存,从而提高大文件处理的性能。例如,以下代码展示了如何使用内存映射文件读取10MB的...

    Java NIO 中英文版

    - Java NIO提供了一组文件系统操作API,例如FileChannel用于读写文件,MappedByteBuffer实现了内存映射文件,可以直接通过内存访问文件内容,提高了读写速度。 4. **缓冲区的分类** - **ByteBuffer**:用于处理...

    Java.NIO资源下载资源下载

    - **内存映射文件 (Memory-Mapped Files)**:探讨了如何利用内存映射文件来提高文件读写的性能。 - **SocketChannel**:介绍了 SocketChannel 的使用,这是在网络编程中常用的一种 Channel。 - **管道 (Pipes)**:...

Global site tag (gtag.js) - Google Analytics