Java NIO学习笔记五 FileChannel(文件通道)

Java NIO FileChannel

  Java NIO FileChannel是连接文件的通道。使用FileChannel,您可以从文件中读取数据和将数据写入文件。Java NIO FileChannel类是NIO用于替代使用标准Java IO API读取文件的方法。

FileChannel无法设置为非阻塞模式。它总是以阻止模式运行。

开启FileChannel

使用之前,FileChannel必须被打开,但是你无法直接打开FileChannel。需要通过InputStream,OutputStream或RandomAccessFile获取FileChannel。

以下是通过RandomAccessFile打开FileChannel的方法:

RandomAccessFile aFile = new RandomAccessFile(“data / nio-data.txt”,“rw”);
FileChannel inChannel = aFile.getChannel();

从FileChannel读取数据

要从FileChannel读取数据,您需要调用read()方法。

代码展示:

ByteBuffer buf = ByteBuffer.allocate(48);

int bytesRead = inChannel.read(buf);

首先:给Buffer分配大小, 从中FileChannel读取的数据会被读入Buffer

其次:调用FileChannel的read()方法。这个方法从FileChannel读取数据读入到Bufferread()方法返回值是int类型,表示多少个字节被插入Buffer。如果返回-1,则到达文件结尾即文件读取完成。

将数据写入FileChannel

使用Fwrite() 方法将数据写入ileChannel,该方法使用Buffer作为参数。

代码展示:

String newData =“要写入文件的新字符串...”+ System.currentTimeMillis();

ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
buf.put(newData.getBytes());

buf.flip();

while(buf.hasRemaining()){
    channel.write(BUF);
}

注意FileChannel的write()在while循环中是如何调用该方法。不能保证write()方法写入的字节数。因此,重复write()调用,直到Buffer没有字节写入。

关闭FileChannel

完成使用后,FileChannel您必须关闭它。

代码展示:

channel.close();    

FileChannel位置

  对FileChannel进行读取或写入时,你会在特定的位置上这样做。您可以通过调用FileChannel的position()方法来获取对象的当前位置。

  还可以通过调用FileChannel的position(long pos)方法设置位置。

Java代码展示:

long pos channel.position();

channel.position(pos +123);

  如果你在文件结束后设置位置,并尝试从通道读取位置,您将获得-1  - 是 文件结尾标记。

  如果在文件结束后设置位置,并写入到通道,文件将被扩展以适应位置和写入数据。这可能会导致“文件孔”,其中磁盘上的物理文件在写入的数据中有间隙。

FileChannel大小

  FileChannel对象的size()方法返回通道连接到的文件的文件大小。

Java代码展示:

long fileSize = channel.size();  

FileChannel截断

  您可以通过调用该FileChannel的truncate()方法来截断文件。当您截断文件时,您可以在给定的长度上将其截断。

代码展示:

channel.truncate(1024);

此示例以1024字节的长度截断文件。

FileChannel Force

  FileChannel的force()方法将所有未写入的数据从通道刷新到磁盘中。在你调用该force()方法之前,出于性能原因,操作系统可能会将数据缓存在内存中,因此您不能保证写入通道的数据实际上写入磁盘。

  force()方法采用布尔值作为参数,说明文件元数据(权限等)是否也应被刷新。

这是一个刷新数据和元数据的示例:

channel.force(true);
原文地址:https://www.cnblogs.com/kuoAT/p/7010056.html