博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
1 Java NIO概述-翻译
阅读量:6984 次
发布时间:2019-06-27

本文共 951 字,大约阅读时间需要 3 分钟。

Java NIO由以下几个部分组成

  • Channels
  • Buffers
  • Selecters

虽然Java NIO除此之外还包括更多的组件,但在我看来,Channel,Buffer,Selecter构成了核心API。其它的组件,如Pipe和FileLock仅仅是这三个核心组件使用的工具类。因此,在NIO概述中我将关注这三个组件。其它组件将在各自的章节中讲到。目录详见左上角。

Channel 和 Buffer

基本上,NIO中的所有IO都由Channel开始。一个Channel与流相似,通过Channel,数据可以被读入到Buffer中,数据同样可以从缓冲区写入到Channel。这里有个图示:

Channel和Buffer有好几种类型。以下是Java NIO中几种主要的Channel。

  • FileChannel
  • DatagramChannel
  • SocketChannel
  • ServerSocketChannel

正如你所见到的,这些通道包括了TCP和UDP的网络IO和文件IO。

与这些类一起的还有些有趣的接口,但是为简单起见,我在概述中尽量不提他们。他们将在其它章节相关的地址进行详细介绍。

以下是一些在Java NIO中实现的核心Buffer。

  • ByteBuffer
  • CharBuffer
  • DoubleBuffer
  • FloatBuffer
  • IntBuffer
  • LongBuffer
  • ShortBuffer

这些Buffer覆盖了你通过IO发送的基本数据类型,:byte, short, int, long, float, double 和 char。

Java NIO也提供了MappedByteBuffer来进行内存文件的映射,我也不打算在概述中进行说明。

Selectors

Selector允许一个线程控制多个通道,如果你的应用程序有许多连接(通道)打开,并且每个连接的流量都非常小,这将变得非常方便,例如在一个聊天服务器中。 下图是一个使用单线程使用Selector.

在使用Selector前需要在Channel中注册它。然后你可以调用select()方法,这个方法将会阻塞直到注册的通道中有准备好的事件。一旦这个方法返回,这个线程可以处理这些事件,事件的例子有新连接进来,数据到达等。

转载地址:http://ioxpl.baihongyu.com/

你可能感兴趣的文章
《PHP精粹:编写高效PHP代码》——第1章面向对象编程
查看>>
美国智能家居止步不前 原因是产品过于碎片化
查看>>
大数据到底是不是“算命”?技术大牛们这样说
查看>>
让智能家居产品操控更简单 快捷键来了
查看>>
《面向对象分析与设计》一3.2 参与者
查看>>
WCF 性能基准报告
查看>>
智迪科技携手海通安恒,启动SAP实施项目
查看>>
机器学习算法在自动驾驶领域的应用大盘点!
查看>>
《深入理解Android:Telephony原理剖析与最佳实践》一1.1 智能手机的系统结构
查看>>
卡斯特罗的离去对古巴科技产业的未来有何影响?
查看>>
维护网络安全要攻防兼备
查看>>
美国第一大移动运营商的5G战略:已进入预商用测试
查看>>
“物联网+云平台”的实验室管理方案,瞄准的是生物医药和化工行业
查看>>
OA系统选型分析之致远OA与华天动力OA
查看>>
联想确认再次裁员 称调整主要分布在海外
查看>>
大鱼吃光小鱼,绝不可能!盘点2016存储行业发生的大事件
查看>>
人中急救穴 也可通过辨别疾病
查看>>
2020年全球云服务规模将达3900亿美元
查看>>
Facebook、Netflix 等多家科技巨头谈“设计”
查看>>
雅虎核心业务售与Verizon:互联网先驱的时代终结
查看>>