辛星2018年nio教程第一篇:初识channel和buffer

2018-02-04  本文已影响0人  辛星0913

先打个小广告,关注辛星教程,我的微信号xinxing0913,该项目源码所在的github地址: https://github.com/xinxing0913/xinxing-nio-guide

对于Java来说,nio是非常重要的一关,我们在这里给一个集中的梳理,不过本系列教程并不复杂,它更加关注的是使用层面的,在之后会有更加深刻的认识。nio是java1.4引入的新的输入输出API,它提供基于块(block)的读写操作,而再之前的io都是基于流(stream)的。
nio的最经典的使用领域则是在服务器领域,其中netty、jetty、tomcat等均通过nio来实现其底层支持,nio在网络层面的使用有非常多的经典范例。

在nio中有三个非常重要的概念,分别是channel、buffer、selector:

这里我们首先来看一个通过nio来读取文本文件的范例把,我们的文本文件内容如下:


demo1.txt.jpg

然后我们来通过一段代码来读写它把,我们的代码内容如下所示:

package com.mengzhidu.nio.demo;

import java.io.FileInputStream;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;

/**
 * 文件读写是我们最熟悉的一个操作
 * 我们这里就使用nio的方式来对一个文件进行读操作
 * 我们读的文件内容是resources目录下的demo01.txt
 */
public class Demo1 {
    public static void main(String[] args) throws Exception {
        String path = "src/main/resources/demo01.txt";
        FileInputStream inputStream = new FileInputStream(path);
        // 得到特定文件的通道
        FileChannel fileChannel = inputStream.getChannel();
        // 申请100个字节大小的字节缓存区
        ByteBuffer buffer = ByteBuffer.allocate(100);
        // 读取文件内容
        fileChannel.read(buffer);
        // 拿到暂存区中的数据内容
        System.out.println("读取的内容: " + new String(buffer.array()));
        // 关闭通道
        fileChannel.close();
    }
}

这里我们首先来解释一下上述代码吧:

上一篇下一篇

猜你喜欢

热点阅读