nio
主要内容
NIO 简介
java NIO 是 java 1.4, 之后新出的一套 IO 接口 NIO 中的 N 可以理解为 Non-blocking,不单纯是 New。
NIO 的特性 NIO 与 IO 区别
IO 是面向流的,NIO 是面向缓冲区的
IO 流是阻塞的,NIO 流是不阻塞的
IO 没有选择器,NIO 有选择器
读数据和写数据方式
从通道进行数据读取 :创建一个缓冲区,然后请求通道读取数据。
从通道进行数据写入 :创建一个缓冲区,填充数据,并要求通道写入数据。
NIO核心组件简单介绍
Buffers
Channels
Selectors
Selector 一般称为选择器,当然你也可以翻译为多路复用器。它是 Java NIO 核心组件中的一个。如此可以实现单线程管理多个 channels, 也就是可以管理多个网络链接。使用 Selector 的好处在于:使用更少的线程来就可以来处理通道了,相比使用多个线程,避免了线程上下文切换带来的开销。
- 数据通过 Channel 读写 Buffer
- Selector 用于检查一个或多个 NIO Channel(通道)的状态是否处于可读、可写, 从 Selector 中选择 Channel 选择器维护注册过的通道的集合,并且这种注册关系都被封装在 SelectionKey 当中
// 分配缓冲区
ByteBuffer buf = ByteBuffer.allocate(28);
// 写数据的两种方式
int bytesRead = inChannel.read(buf); // 从 Channel 中写数据到 Buffer
buf.put(127); // 通过 put 写数据
// Selector 的创建
Selector selector = Selector.open();
// 注册 Channel 到 Selector ( Channel 必须是非阻塞的)
channel.configureBlocking(false);
// 一个 SelectionKey 键表示了一个特定的通道对象和一个特定的选择器对象之间的注册关系
SelectionKey key = channel.register(selector, Selectionkey.OP_READ);
鸣谢
- 关于 Java IO 与 NIO 知识都在这里
- Channels and Buffers、Selectors
相关阅读
文章目录前言1.阻塞与同步2.BIO与NIO对比3.NIO简介4.缓冲区Buffer5.通道Channel6.反应堆7.选择器8.NIO源码分析9.AIO前言 该文是
FPGA nios软核双向IO以及单独引脚的输入输出控制的实
我就是想要实现这样的功能: 学过51单片机的都知道,每一个8位IO口都有单独每一位的读取或者赋值方式,这个在LCD等外设的驱动引脚控制
微信公众号【Java技术江湖】一位阿里 Java 工程师的技术小站。作者黄小斜,专注 Java 相关技术:SSM、SpringBoot、MySQL、分布式、中
当修改salt-minionid操作不当时,会导致master端grains.get会获取两个客户端。每个都无法进行操作。这是由于salt的密钥缓存机