`
dengqsintyt
  • 浏览: 291033 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

Java NIO原理分析及代码实例

阅读更多
    Java NIO非堵塞应用通常适用用在I/O读写等方面,我们知道,系统运行的性能瓶颈通常在I/O读写,包括对端口和文件的操作上,之前,在打开一个I/O通道后,read()将一直等待在端口一边读取字节内容,如果没有内容进来,read()也是傻傻的等,这会影响我们程序继续做其他事情,那么改进做法就是开设线程,让线程去等待,但是这样做也是相当耗费资源的。Hadoop中的RPC机制中,就采用了java nio非阻塞通讯的方式对hdfs文件进行读写操作。为了更深入的了解Java ni非阻塞通讯原理,首先就要了解一下阻塞io通讯模型;然后再去对比的理解Java nio阻塞通讯;最后通过可以写一非阻塞nio通讯的server代码和client代码。退出
一、Java阻塞io原理模型、Java nio非阻塞通讯模型的区别
 
         1.阻塞io通讯模型
 
          如果对阻塞I/O已有了一定了解,那么我们知道阻塞I/O在调用InputStream.read()方法时是阻塞的,它会一直等到数据到来时(或超时)才会返回;同样,在调用ServerSocket.accept()方法时,也会一直阻塞到有客户端连接才会返回,每个客户端连接过来后,服务端都会启动一个线程去处理该客户端的请求。阻塞I/O的通信模型示意图如下:

 


       
          通过上图,你会发现阻塞I/O存在一些缺点。根据阻塞I/O通信模型,总结两大缺点:
          A. 当客户端多时,会创建大量的处理线程。且每个线程都要占用栈空间和一些CPU时间
          B. 阻塞可能带来频繁的上下文切换,且大部分上下文切换可能是无意义的。
         通过分析,这种情况下非阻塞式I/O就有了它的应用前景。
         2.非阻塞io通讯模型
 
          Java nio是在jdk1.4开始使用的,它既可以说成“新I/O”,也可以说成非阻塞式I/O。下面是java NIO的工作原理:

          1. 由一个专门的线程来处理所有的 IO 事件,并负责分发。
          2. 事件驱动机制:事件到的时候触发,而不是同步的去监视事件。
          3. 线程通讯:线程之间通过 wait,notify 等方式通讯。保证每次上下文切换都是有意义的。减少无谓的线程切换。
 
每个线程的处理流程大概都是读取数据、解码、计算处理、编码、发送响应
 
          Java NIO的服务端只需启动一个专门的线程来处理所有的 IO 事件,这种通信模型是怎么实现的呢?呵呵,我们一起来探究它的奥秘吧。java NIO采用了双向通道(channel)进行数据传输,而不是单向的流(stream),在通道上可以注册我们感兴趣的事件。一共有以下四种事件:
          
1.服务端接收客户端连接事件:SelectionKey.OP_ACCEPT(16)
2.客户端连接服务端事件:SelectionKey.OP_CONNECT(8)
3.读事件:SelectionKey.OP_READ(1)
4.写事件:SelectionKey.OP_WRITE(4)
 
          服务端和客户端各自维护一个管理通道的对象,我们称之为selector,该对象能检测一个或多个通道 (channel) 上的事件。我们以服务端为例,如果服务端的selector上注册了读事件,某时刻客户端给服务端发送了一些数据,阻塞I/O这时会调用read()方法阻塞地读取数据,而NIO的服务端会在selector中添加一个读事件。服务端的处理线程会轮询地访问selector,如果访问selector时发现有感兴趣的事件到达,则处理这些事件,如果没有感兴趣的事件到达,则处理线程会一直阻塞直到感兴趣的事件到达为止。下面是我理解的java NIO的通信模型示意图

 
 
二、实战:代码分析
         1.server端代码
          
         2.client端代码
            
  • 大小: 85.1 KB
  • 大小: 130.7 KB
  • 大小: 71.8 KB
分享到:
评论

相关推荐

    Java NIO原理 图文分析及代码实现

    ### Java NIO原理 图文分析及代码实现 #### 前言 在深入探讨Java NIO之前,我们先简要回顾一下NIO的概念及其引入的原因。随着互联网的发展,越来越多的应用程序需要处理高并发的网络连接请求。传统的阻塞I/O模型在...

    Java NIO——Selector机制解析三(源码分析)

    本文将深入探讨Java NIO中的Selector机制,并通过源码分析来理解其实现原理。 Selector机制是Java NIO中的核心组件,它允许单线程同时监控多个通道(Channels)的状态变化,例如连接就绪、数据可读或可写等。这种...

    Java nio源码

    Java NIO,全称为New Input/Output,是Java在1.4版本引入的一个新特性,旨在提供一种更高效、更具选择性的I/O模型。...通过分析NIO源码,我们可以深入了解其内部工作原理,进一步优化和调试相关代码。

    javaNIO javaNIO

    ### Java NIO与ByteBuffer详解 #### 一、Java NIO简介 Java NIO(New I/O)是Java SE 1.4版本引入的一种新的I/O处理方式,它提供了与传统BIO(Blocking I/O)不同的数据处理机制。NIO的核心组件包括`Channels`、`...

    基于JavaNIO的非阻塞通信的研究与实现

    本文探讨了Java NIO(New I/O)框架中的非阻塞通信机制,并对其原理及应用进行了深入研究。NIO是一种现代I/O处理方法,通过引入缓冲区、通道和选择器等新概念,显著提升了文件处理和网络服务器程序的性能。本文首先...

    一个NIO服务端,客户端的例子

    总的来说,这个NIO服务端和客户端的例子可以帮助我们深入理解Java NIO和Netty框架的工作原理,学习如何构建高效、可靠的网络应用。通过实践和分析这个示例代码,我们可以更好地掌握异步I/O、事件驱动编程以及Netty...

    linux nio和java.zip

    在“linux nio和java.zip”压缩包中的“linux nio和java.pdf”文件,很可能是详细讲解了Linux NIO和Java NIO的相关知识,包括概念、API使用、实例分析以及性能优化等方面,对于想深入了解和实践NIO编程的开发者来说...

    Java程序设计语言源代码

    Java程序设计语言源代码是学习和理解Java技术体系的重要途径,尤其对于开发者而言,阅读和分析源代码能够深化对语言特性的理解,提高编程技能。Java作为一种广泛使用的面向对象编程语言,其源代码包含了丰富的编程...

    网络与nio

    标题中的“网络与nio”指的是Java的非阻塞I/O(Non-blocking I/O)特性,主要涉及Java NIO(New IO)库。Java NIO在Java 1.4版本引入,为开发者提供...通过分析和运行这些代码,我们可以更好地掌握Java NIO的实践技巧。

    JAVA上百实例源码以及开源项目源代码

    Java波浪文字制作方法及源代码 1个目标文件 摘要:Java源码,初学实例,波浪文字 Java波浪文字,一个利用Java处理字符的实例,可以设置运动方向参数,显示文本的字符数组,高速文本颜色,显示字体的 FontMetrics对象,...

    java编程思想第四版源代码.7z

    2. **面向对象编程**:Java是面向对象的语言,源代码中会有大量的类定义、对象实例化、封装、继承、多态等面向对象概念的实例。你可以从中学习如何设计和实现类,理解对象间的关系,以及如何利用接口实现多态性。 3...

    java nio 详解

    为了更好地理解NIO的工作原理,建议通过编写代码来实践。下面是一些实践NIO编程的关键步骤: 1. **创建缓冲区**:根据需要选择合适的缓冲区类型,如`ByteBuffer`。 2. **打开通道**:使用`newSocketChannel()`或`...

    基于Java的实例源码-NIO网络框架 xSocket.zip

    - **理解NIO原理**:深入学习Java NIO的底层机制,有助于更好地使用xSocket。 - **阅读源码**:通过分析xSocket的源码,可以了解其设计思路和实现细节,提高解决问题的能力。 - **实践项目**:参与实际项目开发,...

    java 读取写入csv

    本文将深入探讨如何使用Java进行CSV文件的操作,基于提供的代码片段,我们将详细解析其工作原理,并扩展相关的知识点。 #### 一、Java读取CSV文件 Java读取CSV文件主要依赖于第三方库,如Apache Commons CSV或...

    Java Http通信测试代码

    在Java编程语言中,HTTP...通过分析和学习这些源代码,开发者可以深入理解Java HTTP通信的原理,并能运用到自己的项目中,比如创建RESTful客户端、实现自动化测试脚本等。同时,这也是一种提升网络编程技能的有效途径。

    164个完整的Java源程序代码

    通过研究这些源代码,我们可以深入理解Java编程的核心原理,并提升实际编程技能。 首先,这些Java源代码可能包括了基础的语法结构,例如类(Class)、对象(Object)、方法(Method)、变量(Variable)等。Java中...

    NIOServer

    【标题】:“NIOServer”是...通过阅读和分析“NIOServer.java”,开发者可以深入理解Java NIO的工作原理,以及如何利用NIO实现高效的网络服务器。同时,这个项目也可以作为参考,帮助开发者构建自己的网络应用或服务。

Global site tag (gtag.js) - Google Analytics