`
Tonyguxu
  • 浏览: 277829 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

【Java NIO】内存映射文件

 
阅读更多

java.nio包包含对下列特性的支持:

1.字符集编码器和解码器

2.非阻塞的I/O

3.内存映射文件

4.文件加锁机制

 

 

内存映射文件

 

file-mapping model

 

 

缓冲区数据结构——Buffer

 

 

在使用内存映射时,我们创建了单一的缓冲区横跨整个文件或部分文件区域。

类继承结构如下:

上面Buffer都没有提供构造,可以通过如下方法来获得Buffer实例:

static xxxBuffer allocate(int capacity)

 

Channel

Channel类似传统io里的流,但与流不同在于:

1.channel可以直接将指定文件的部分或者全部映射成Buffer

2.程序通过buffer读写channel中的数据。

比如想从channel中读取一些数据,首先会将这些数据读入buffer,然后程序再从buffer中读。写也一样要通过buffer往channel中写数据。

 

Channel的继承结构:

 

 

文件通道

 

打开Channel

XxxChannel = XxxInputStream / XxxOutputStream .getChannel()

 

FileChannel 常用方法

MapperByteBuffer map (FileChannel.MapMode mode, long position, long size);

将channel中部分or全部数据映射成buffer

 

通过Channel 和 Buffer从文件中读数据

FileInputStream input = new FileInputStream(fileName);
FileChannel channel = input.getChannel();

MappedByteBuffer buffer = channel.map(FileChannel.MapMode.READ_ONLY/READ_WRITE/PRIVATE,
    long position, long size);//将文件的一个区域映射到内存中
buffer.get();//对buffer的读操作

 

通过Buffer 和 Channel向文件中写数据

FileOutputStream output = new FileOutputStream(fileName);
FileChannel channel = output.getChannel();

MappedByteBuffer buffer = channel.map(FileChannel.MapMode.READ_ONLY/READ_WRITE/PRIVATE,
    long position, long size);//将文件的一个区域映射到内存中
buffer.put();//对buffer的写操作

 

FileChannel的内部类里定义了文件映射模式

public static class MapMode {

	/**
	 * Mode for a read-only mapping.
	 */
	public static final MapMode READ_ONLY
	    = new MapMode("READ_ONLY");

	/**
	 * Mode for a read/write mapping.
	 */
	public static final MapMode READ_WRITE
	    = new MapMode("READ_WRITE");

	/**
	 * Mode for a private (copy-on-write) mapping.
	 */
	public static final MapMode PRIVATE
	    = new MapMode("PRIVATE");

	private final String name;

	private MapMode(String name) {
	    this.name = name;
	}

	/**
	 * Returns a string describing this file-mapping mode.
	 *
	 * @return  A descriptive string
	 */
	public String toString() {
	    return name;
	}
    }

 

实例1:文件拷贝

 

 

实例2:文件追加内容

 

通道只能在字节缓冲区上操作

 

 

socket通道

 

 

 

分享到:
评论

相关推荐

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

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

    java nio 包读取超大数据文件

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

    java nio 写文件

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

    java NIO.zip

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

    java NIO实例

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

    java NIO 写文件

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

    Java NIO英文高清原版

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

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

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

    NIO与零拷贝_javanio_nio和零拷贝_

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

    Java NIO测试示例

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

    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