java的NIO编程

时间:2023-04-03 20:29:08 来源: 腾讯云

Java NIO(New I/O)是一种可伸缩且非阻塞的 I/O,与传统的 Java IO 不同。它允许同时处理多个连接,并且能够更快地处理 I/O 操作,是构建高性能、可伸缩和并发应用程序的重要组成部分。

Java NIO 的核心是 Channel、Buffer 和 Selector。Channel 是连接源和目标的通道,Buffer 是数据传输的缓冲区,Selector 用于监视 Channel 中的事件并选择可用的 Channel 进行操作。下面我们来看一下 Java NIO 的示例。

Channel

在 Java NIO 中,所有的 I/O 操作都是通过 Channel 来进行的。Channel 类似于传统的流,但又有所不同。在 Channel 中,数据可以从 Channel 中读取到 Buffer 中,也可以将数据从 Buffer 写入 Channel 中。


(资料图片仅供参考)

下面是一个从文件中读取数据并输出到控制台的示例:

javaCopy codeimport java.io.*;import java.nio.*;import java.nio.channels.*;public class ChannelExample {    public static void main(String[] args) throws IOException {        RandomAccessFile file = new RandomAccessFile("test.txt", "rw");        FileChannel channel = file.getChannel();        ByteBuffer buffer = ByteBuffer.allocate(1024);        while (channel.read(buffer) != -1) {            buffer.flip();            while (buffer.hasRemaining()) {                System.out.print((char) buffer.get());            }            buffer.clear();        }        channel.close();        file.close();    }}

在上述示例中,我们使用 FileChannel 打开一个文件,并使用 ByteBuffer 分配一个缓冲区。然后使用 channel.read() 方法从文件中读取数据到缓冲区,使用 buffer.flip() 方法将缓冲区的指针移到缓冲区的起始位置,并使用 buffer.hasRemaining() 和 buffer.get() 方法遍历缓冲区中的数据。

Buffer

Buffer 是一个用于读写数据的缓冲区,它可以存储任何类型的数据,例如字节、字符、整数等等。Buffer 是一个抽象类,主要有以下几种子类:ByteBuffer、CharBuffer、ShortBuffer、IntBuffer、LongBuffer、FloatBuffer 和 DoubleBuffer。

下面是一个使用 ByteBuffer 存储数据并将其输出到控制台的示例:

import java.nio.*;public class BufferExample {    public static void main(String[] args) {        ByteBuffer buffer = ByteBuffer.allocate(1024);        buffer.put("Hello, world!".getBytes());        buffer.flip();        while (buffer.hasRemaining()) {            System.out.print((char) buffer.get());        }        buffer.clear();    }}

在上述示例中,我们使用 ByteBuffer 分配一个缓冲区,并使用 put() 方法将一个字符串存储到缓冲区中。然后使用 flip() 方法将缓冲区的指针移到缓冲区的起始位置,并使用 hasRemaining() 和 get() 方法遍历缓冲区中的数据。

Selector

Selector 用于监视 Channel 中的事件并选择可用的 Channel 进行操作。在 Java NIO 中,一个线程可以同时处理多个连接,因此它比传统的 Java IO 更快和更可伸缩。

下面是一个使用 Selector 监视 Channel 的示例:

javaCopy codeimport java.io.*;import java.nio.*;import java.nio.channels.*;public class SelectorExample {    public static void main(String[] args) throws IOException {        ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();        serverSocketChannel.socket().bind(new InetSocketAddress("localhost", 8080));        serverSocketChannel.configureBlocking(false);        Selector selector = Selector.open();        serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);        while (true) {            int readyChannels = selector.select();            if (readyChannels == 0) {                continue;            }            for (SelectionKey key : selector.selectedKeys()) {                if (key.isAcceptable()) {                    ServerSocketChannel server = (ServerSocketChannel) key.channel();                    SocketChannel client = server.accept();                    client.configureBlocking(false);                    client.register(selector, SelectionKey.OP_READ);                } else if (key.isReadable()) {                    SocketChannel client = (SocketChannel) key.channel();                    ByteBuffer buffer = ByteBuffer.allocate(1024);                    client.read(buffer);                    buffer.flip();                    while (buffer.hasRemaining()) {                        System.out.print((char) buffer.get());                    }                }                selector.selectedKeys().remove(key);            }        }    }}

在上述示例中,我们使用 ServerSocketChannel 打开一个服务器,并使用 Selector 监视该服务器。当有客户端连接时,使用 accept() 方法获取客户端的 SocketChannel 并注册到 Selector 中,并指定监听 OP_READ 事件。当客户端向服务器发送数据时,使用 read() 方法将数据读取到 ByteBuffer 中,并使用 buffer.hasRemaining() 和 buffer.get() 方法遍历 ByteBuffer 中的数据。

标签:

精彩推送

世界热点!美银证券:维持中国光大银行(06818.HK)“买入”评级 目标价升至2.8港元

美银证券发布研究报告称,维持中国光大银行(06818 HK)“买入”评级,将2023-24年每股盈测下调6%至7%,...

来源:2023.03.27

环球热门:我的世界盔甲架英文是什么_我的世界盔甲架英文

1、盔甲架的合成需要6根木棍+1个石台阶,在工作台中的摆放方式是最上面一行放木棍,最下面的中间一格放...

来源:2023.03.27

全球快播:海南多市县发布冰雹橙色预警信号,未来几天雨雨雨

小伙伴出行的时候要注意啦海南多市县发布冰雹橙色预警信号海口市气象台2023年03月27日08时02分发布冰雹...

来源:2023.03.27

长亮科技:公司研发中心目前设立有人工智能研究的专门机构,正在开展相关场景化研究工作

长亮科技30034803月27日在投资者关系平台上答复了投资者关心的问题投资者董秘你好请问公司有涉及人工智...

来源:2023.03.27

环球热议:组图 | 春天里 随“农委员”去田间地头

组图|春天里随“农委员”去田间地头

来源:2023.03.27

中重科技 今日新股申购_快播

股票名称:中重科技,申购代码:732135,申购价格:17 80元,中签缴款日期:2023-03-29

来源:2023.03.27

今日快看!屏蔽线怎样接线_屏蔽线的接法

1、屏蔽线接插头的时候把屏蔽线里的屏蔽层剪齐,放到插头的连接帽里面,注意不要把屏蔽层里的金属丝线和...

来源:2023.03.27

镇平县召开营商环境一季度调度会-速看

镇平县召开营商环境一季度调度会

来源:2023.03.26

宓妃怎么读音_宓妃的拼音介绍

解答:1、宓妃拼音。2、传说中的洛水女神。《楚辞离骚》:“我让红龙骑着云去找宓妃。”王一注:“宓妃,...

来源:2023.03.26

新闻快讯

X 关闭

X 关闭

新闻快讯