`
san_yun
  • 浏览: 2638943 次
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

java nio 学习

    博客分类:
  • NIO
 
阅读更多

看完以后,发现这篇文章虽然写的时间较早,但是我这几天看到的给我启发最大的一篇资料。

我下载文章下面附带的源代码,看了几遍,我的思路忽然开朗起来。

重新改写之前几天写的代码,经过这一天的努力,写出的代码经过测试,不管是并发性、处理能力方面都有明显的提升。

与 以前用传统的io + socket + 多线程写的HTTP服务器对比,用ab测试并发性,nio 处理 2000 并发一点儿问题都没有,反应的速度也相当的快,而传统的io处理方式在处理1000个并发的过程中,客户端ab就崩溃了,NIO与传统的IO测试对比结 果:

传统的IO + socket需要几百、上千个线程来处理客户端的请求,而 NIO 只需要几个线程就搞定;

NIO内存占用相比传统的IO降低 80%;

NIO的cpu占用相比传统的IO 降低 20%;

NIO处理能力相比传统的IO 却提升了 30%;

 

我今天使用NIO写的代码结构相当简单:

1个 Selector 主线程 + 1个 Reader 线程 + 1个 Writer 线程

就能处理几百、上千的并发请求,处理的速度相当的快,内存占用相当的低。

看到测试的结果,我也深刻体会到了nio的一个优点:该read的时候再read,该write时候再write。

不像传统的io,用多个线程处理多个用户的多个连接请求,不管用户提交的数据是否到达,先 read(),没有数据可读的时候,就在那阻塞着。

 

不过话又说回来,传统的io,基于流(Stream),也有它的优点,比如处理流程简单,代码写起来相比nio要简单许多。

 

在这里我还想说一点体会,就是我在网上这几天找相关资料,发现80%的文章介绍的都不够深入,提供的代码基本上都是单线程的,非常适合用来处理短连接,这也一直给我一种错觉,难道NIO不适合处理长连接?

今天找到的这篇:http://www.ibm.com/developerworks/cn/java/l-niosvr/

查看了文章里提供的源代码,使用了三个线程(Selection线程,Reader线程,Write线程),使nio处理长连接成为可能,只需简单修改一下,就OK了。

分享到:
评论

相关推荐

    JAVA NIO学习网站

    在《JAVA NIO学习网站》的博文中,作者可能详细讲解了如何使用这些组件以及它们之间的交互。例如,可能会介绍如何创建并配置通道,如何使用缓冲区读写数据,如何注册通道到选择器,以及如何利用选择器处理多个并发...

    JAVA NIO 学习资料

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从JDK 1.4版本开始引入的一种新的IO模型,它为Java应用程序提供了更高效的数据传输方式,尤其适用于高并发、大数据量的网络服务。与传统的IO...

    java NIO 学习 聊天室程序 (3)

    在这个“Java NIO 学习 聊天室程序”项目中,我们将深入探讨NIO如何用于创建一个聊天室程序。这个程序可能包含以下几个关键部分: 1. **服务器端**:服务器端使用NIO的ServerSocketChannel监听客户端连接。当新的...

    Java NIO学习笔记——ByteBuffer用法

    ByteBuffer的用法是Java NIO学习中的核心内容。 首先,我们了解下ByteBuffer的基本概念。ByteBuffer是一个字节缓冲区,可以存储字节序列。在NIO中,所有的数据读写都通过缓冲区进行,ByteBuffer与其他类型的Buffer...

    Java NIO学习资料+代码.zip

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java在JDK 1.4版本引入的一种新的I/O模型,它为Java开发者提供了更高效、...学习和掌握Java NIO,能够帮助开发者编写出更高效、更易维护的网络程序。

    java NIO学习系列 笔记

    Java NIO(New Input/Output)是Java标准库在JDK 1.4版本中引入的一个新特性,它提供了一种不同于传统IO流的高效I/O处理方式。NIO的核心概念包括通道(Channel)和缓冲区(Buffer),这两个组件使得数据以块的形式...

    JAVA NIO学习笔记.docx

    Java NIO(New Input/Output)是Java标准库在JDK 1.4引入的一组新的I/O API,它提供了一种不同于传统IO的高效、非阻塞的I/O操作方式。NIO的核心概念包括Channel、Buffer和Selector,它们共同构建了一个与操作系统...

    java nio 入门

    Java NIO(New Input/Output)是Java标准库中的一部分,自Java 1.4版本引入,为开发者提供了更高效的数据处理方式。相比于传统的IO模型,NIO具有非阻塞和选择器等特性,适用于高并发、大数据量的场景。在本文中,...

    Java NIO英文高清原版

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java平台中用于替代标准I/O(BIO)模型的一种新机制。...学习和理解Java NIO以及Netty的使用,对于提升Java网络编程的能力至关重要。

    Java NIO 中文 Java NIO 中文 Java NIO 中文文档

    Java NIO 深入探讨了 1.4 版的 I/O 新特性,并告诉您如何使用这些特性来极大地提升您所写的 Java 代码的执行效率。这本小册子就程序员所面临的有代表性的 I/O 问题作了详尽阐述,并讲解了 如何才能充分利用新的 I/O ...

    javaNIO.xmind

    自己总结的java中NIO的笔记,绘制了详细的思维导图,每个思维导图中均有详细的博文解释,方便大家学习和理解,免费分享给大家。适合java的爱好者和学习者

    javaNIO学习笔记(csdn)————程序.pdf

    Java NIO,全称Non-Blocking Input/Output,是非阻塞式输入输出,它是Java从1.4版本开始引入的一种新的I/O模型,为Java程序员提供了处理I/O操作的新方式。NIO的主要特点是其能够使Java程序以更有效的方式处理I/O流,...

    java nio入门学习,两个pdf

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统I/O模型的新技术。在Java 1.4版本中引入,NIO提供了一种全新的I/O编程方式,使得Java开发者能够更高效地处理I/O操作...

    java NIO技巧及原理

    Java NIO(New Input/Output)是Java标准库提供的一种I/O模型,它与传统的 Blocking I/O(IO)相比,提供了更加高效的数据传输方式。在Java NIO中,"新...学习和掌握NIO,对于提升Java应用的性能和扩展性至关重要。

    Java NIO 国外 PPT 课件(精华)

    总的来说,这些PPT课件构成了一个全面的Java NIO学习资源,涵盖了NIO的基本概念、高级特性、实际应用以及优化策略。通过深入学习,开发者不仅可以理解NIO的工作原理,还能掌握如何在实际项目中有效地利用这一强大的...

    java NIO实例

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种新的I/O模型,它为Java应用程序提供了更高效的数据传输...学习和理解NIO,对于开发高并发、高性能的Java应用至关重要。

Global site tag (gtag.js) - Google Analytics