`
Tonyguxu
  • 浏览: 277880 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

【Java NIO】选择器

 
阅读更多

====笔记=====

Java NIO提供选择器(Selectors),选择器提供选择执行已经就绪的任务的能力,使得多元IO成为可能。就绪选择和多元IO使得单线程能够有效率地同时管理多个I/O通道(channels)。

——一种新的IO模型

我的理解:一个工作线程通过“选择器”监控多个IO通道,当IO通道没有就绪的任务时,该线程可以做其他事情(不用阻塞),当IO通道上有任务就绪时,该线程能够处理该任务。

 

 

三个主要的类


keyword: 可选择通道   注册  选择器对象   select()  选择键  选择键集合  就绪的通道


疑问:将通道(Channel)注册(register)到选择器(Selector),注册方法是通道提供还是选择器提供呢?

——观察者模式 http://nemogu.iteye.com/blog/1407857

SelectionKey register(Selector sel, int ops, Object att)
Registers this channel with the given selector, returning a selection key.
在visitor模式中,访问者访问节点,首先通过node.accept(visitor)
一点收获:如果将A注册到B,则A提供一个register方法,a.register(b)

观察者模式中也是由主题来提供register方法,主题调用该注册方法将观察者注册进来。

 

SelectionKey(选择键)

一个selectableChannel可以注册到多个selector上,并且一个selector也可以监控多个selectableChannel,通过选择键来表示一个通道和选择器之间的注册关系。

 

分享到:
评论

相关推荐

    java NIO.zip

    通过注册感兴趣的事件(如读、写或连接就绪)到选择器,当这些事件发生时,选择器会返回一个包含已准备好的通道的`SelectionKey`集合,然后开发者可以逐个处理这些通道,而无需为每个连接创建单独的线程。...

    Java NIO英文高清原版

    6. **多路复用器(Multiplexing)**:Java NIO的选择器实现了I/O多路复用,即单个线程可以同时处理多个连接,这在处理大量并发连接时非常有用。 7. **管道(Pipe)**:管道是两个线程间进行单向数据传输的通道。一...

    Java IO_NIO

    **Java NIO选择器** 选择器用于监听多个通道的事件,如连接建立、数据到达、连接关闭等。通过注册通道到选择器并设置关注的事件类型,可以选择器在单个线程中高效地处理多个通道。当某个事件发生时,选择器会返回一...

    java NIO 视频教程

    Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java...Java NIO引入了选择器的概念,选择器用于监听多个通道的事件(比如:连接打开,数据到达)。因此,单个的线程可以监听多个数据通道。

    基于Java NIO反应器模式设计与实现

    Java NIO的反应器模式设计与实现,首先涉及到理解Java NIO的基本概念,如通道(Channel)、缓冲区(Buffer)、选择器(Selector)等。通道是进行读写操作的基础,是连接I/O源和数据的端点。缓冲区是在NIO中用于数据...

    java NIO技巧及原理

    2. **选择器使用**:选择器的选择和配置对性能有很大影响,需要根据具体需求进行调整。 3. **异常处理**:NIO的错误处理相对复杂,需要对各种可能的异常情况有所预见。 4. **线程安全**:在多线程环境下使用NIO时,...

    一个java NIO的例子

    而Java NIO引入了选择器(Selector)和通道(Channel)的概念,允许单个线程同时处理多个连接,大大提高了系统在高并发环境下的性能。 本例子中的"NioServer"可能是一个简单的Java NIO服务器端程序,用于演示如何...

    java NIO实例

    1. **Selector(选择器)**:选择器是NIO的核心组件,它能够监控多个通道(Channel)的状态变化,当某个通道准备进行读写操作时,选择器会通知用户线程。这样,一个线程就可以管理多个通道,实现多路复用。 2. **...

    Java NIO Socket基本

    `java.nio.Selector`是选择器的主要接口。 4. **管道(Pipe)**:在某些特定情况下,两个线程之间可以使用`java.nio.Pipe`进行单向数据传递。 5. **文件系统API**:NIO还提供了`java.nio.file`包,包含一系列与...

    Java NIO测试示例

    NIO的核心组件包括通道(Channel)、缓冲区(Buffer)和选择器(Selector)。下面将对这些组件进行详细阐述: 1. **通道(Channel)**: 通道是数据传输的载体,类似于传统I/O中的流。Java NIO提供了多种类型的...

    java NIO推送实例

    - **选择器(Selectors)**:选择器允许单个线程监视多个通道,从而实现多路复用,提高系统资源利用率。 2. **NIO在消息推送中的应用** - **服务器端(DeskAppServer)**:服务端通常会开启一个监听通道,等待...

    java nio入门学习,两个pdf

    3. **选择器(Selectors)**:选择器用于监控多个通道的状态,当某个通道准备就绪时,选择器会返回一个包含就绪通道的集合,从而避免了轮询检查所有通道的开销。 4. **文件系统(File Systems)**:NIO提供FileChannel...

    Java NIO 中英文版

    - **选择器**:Java NIO中的选择器允许单个线程监控多个通道,当这些通道准备进行读写操作时,选择器会通知线程,从而提高了多路复用的能力,有效利用了系统资源。 3. **文件系统操作** - Java NIO提供了一组文件...

    java nio 读文件

    NIO的主要特点是面向缓冲区,非阻塞I/O,以及选择器,这些特性使得NIO在处理大量并发连接时表现出更高的效率。在本篇文章中,我们将深入探讨Java NIO如何读取文件。 一、NIO的基本概念 1. 缓冲区(Buffer):NIO的...

Global site tag (gtag.js) - Google Analytics