http://www.csdnjava.com/forum.php?mod=viewthread&tid=52809
2013/3/10 0:44:36
细微的行动远胜空美的计划,去做,才会发现时间不够用,才会体会到精髓,才会体会到真正的“道”,才能真正掌控。
zero-copy-capable
通常的数据拷贝受制于传统的操作系统或通信协议,网卡-->内核-->用户空间,比如linux-网卡的ring-buffer
zero-copy减少数据在存储器之间不必要的拷贝和共享总线操作的次数。
DMA(Direct Memory Access,直接内存存取)
DMA传输时, DMA控制器直接掌管总线,总线控制权转移:CPU-->DMA控制器-->CPU
内存映射文件和锁
Win32用CreateFileMapping函数。特别适合大数据文件的copy。
与虚拟内存有些类似,把文件映射到到一块内存。内存映射文件保留一个地址空间的区域,将物理存储器提交给此区域,先对文件进行映射,、就可以用内存读/写指令访问,而不是用ReadFile和WriteFile这样的I/O系统函数,从而提高了文件存取速度。
netty-异步。
write() 之后并不直接写数据, 而是将数据写入一个队列, 然后返回. 由worker线程取出, 执行写操作, 成功后发送事件, 也就调用了你的那个 Listener
一. 介绍NIO
java.nio.* 引入了四个关键的抽象数据类型
1.Buffer : 包含数据用于读写的线形表结构。其中DirectByteBuffer,MappedByteBuffer用于内存映射文件的I/O操作。
数据流:应用程序<-->数据缓存<-->操作系统数据IO设备,(Direct)的ByteBuffer是一块连续的空间,是native代码,内存的分配不在Java的堆栈中,不受java内存回收的影响.
视图缓冲:在一个数据缓冲之上也可以建立多个逻辑的buffer
2.Charset : Unicode字符序列<-->字节序列的相互映射。
3.Channel : connection to an entity such as a hardware device, a file, a network socket and other I/O operations
4.Selector:A multiplexor多路复用器 of SelectableChannel(unix的select()/poll(),win32的WaitForSingleEvent())
NIO需要Selector向SelectableChannel注册特定的事件,等待通知,传统I/O一直阻塞不需要通知。可以用一个线程就能同时有效地管理多个IO通道,需要操作系统的支持。
相关推荐
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java平台中用于替代标准I/O(BIO)模型的一种新机制。NIO在Java 1.4版本引入,提供了更高效的数据处理和通道通信方式,特别适用于高并发、大数据...
### Java NIO 处理超大数据文件的知识点详解 #### 一、Java NIO简介 Java NIO(New IO)是Java平台上的新输入/输出流API,它提供了与传统IO(即Java IO)不同的数据处理方式。NIO在Java 1.4版本引入,并在后续版本...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统的I/O模型的新技术。自Java 1.4版本引入NIO后,它为Java开发者提供了更高效的数据传输方式,尤其是在处理大量并发...
在Java编程领域,NIO(New IO)是一个重要的特性,它是Java 1.4版本引入的,用于替代标准的IO API。NIO提供了一种非阻塞I/O操作的方式,特别适用于处理大量的并发连接,例如在文件传输、网络通信等场景。本主题...
在Java编程领域,NIO(New Input/Output)是一个重要的概念,它提供了非阻塞I/O操作的能力,相比传统的BIO(Blocking I/O),在处理大量并发连接时表现出更高的效率和性能。本项目"基于nio的简易聊天室"旨在通过NIO...
赠送jar包:xnio-nio-3.8.0.Final.jar; 赠送原API文档:xnio-nio-3.8.0.Final-javadoc.jar; 赠送源代码:xnio-nio-3.8.0.Final-sources.jar; 赠送Maven依赖信息文件:xnio-nio-3.8.0.Final.pom; 包含翻译后的API...
它基于Java NIO API,利用其非阻塞I/O特性,可以同时处理大量连接,尤其适合于高并发的网络环境。HttpCore NIO 4.3版是对该框架的进一步优化和完善,增强了对HTTP/1.1协议的支持,同时保持了良好的兼容性和稳定性。 ...
《NIO与Socket编程技术指南》是一本深入探讨Java NIO(New Input/Output)和Socket编程的专业书籍,由高洪岩撰写。本书主要针对Java开发者,旨在帮助他们理解和掌握这两种在开发网络应用中至关重要的技术。 Java ...
### Java NIO 详细教程知识点解析 #### 一、Java NIO 概述 Java NIO(New IO)是Java平台提供的一种新的IO操作模式,它首次出现在Java 1.4版本中,并在后续版本中不断完善。Java NIO 的设计目的是为了克服传统Java ...
**NIO(New Input/Output)是Java编程语言中用于替代标准I/O(BIO,Blocking I/O)的一组API,它提供了非阻塞式的I/O操作方式,极大地提升了Java在处理I/O密集型应用时的性能。NIO在Java 1.4版本中被引入,之后在...
本项目"基于Spring Boot + NIO实现的电商平台见证宝服务"旨在利用Spring Boot的便捷性与NIO(非阻塞I/O)的效率,来打造一个高效、稳定且可扩展的服务。下面将详细阐述其中涉及的关键技术点。 首先,Spring Boot是...
Java作为一门广泛使用的开发语言,提供了多种I/O(Input/Output)通信模型,包括传统的阻塞I/O(BIO)、非阻塞I/O(NIO)以及异步I/O(AIO)。这些通信模型在不同的场景下有着各自的优势,理解和掌握它们对于优化...
设计思想: 每次通过nio读取字节到 fbb中 然后对fbb自己中的内容进行行判断即 10 回车 13 行号 0 文件结束 这样字节的判断,然后 返回行 如果 到达 fbb的结尾 还没有结束,就再通过nio读取一段字节,继续处理...
### Java NIO (New IO) 详解 #### 1. 引言 在Java的世界里,I/O(Input/Output)操作是程序与外部环境进行交互的重要方式之一。随着技术的发展,传统I/O模型逐渐显露出一些局限性,特别是在处理高并发场景下,其...
Java NIO(New IO)是Java 1.4版本引入的一个新模块,它提供了一种不同于传统IO(基于字节流和字符流)的I/O操作方式。传统的IO模型是阻塞式的,而NIO的核心特点是非阻塞,这使得在处理大量并发I/O请求时更为高效。...
Java NIO(Non-blocking Input/Output)是一种在Java中处理I/O操作的新方式,相比于传统的BIO(Blocking I/O),NIO提供了更高效的数据传输能力,尤其适合于高并发、低延迟的网络应用,如聊天服务器。在这个场景下,...