NIO 编程模型】的更多相关文章

终于,这两天的考试熬过去了, 兴致冲冲的来整理笔记来, 这篇博客是我近几天的NIO印象笔记汇总,记录了对Selector及Selector的重要参数的理解,对Channel的理解,常见的Channel,对NIO事件驱动的编程模型的理解,NIO与传统IO的对比,NIO的TCP/IP编程的实践. Channel 什么是Channel 这个概念绝对是一级概念,Channel是一个管道,用于连接字节缓冲区和另一端的实体, 这个字节缓冲区就是ByteBuffer, 另一端的实体可以是一个File 或者是…
NIO 编程模型 Doug Lea 在 Scalable IO in Java 的 PPT 中描述了 Reactor 编程模型的思想,大部分 NIO 框架和一些中间件的 NIO 编程都与它一样或是它的变体.本文结合 PPT 按照自己的理解整理而来,最终编写了一个简单的 NIO 回显服务. Reactor 之所以高效是因为采用了分而治之和事件驱动的设计.大部分网络服务像 Web 服务器.分布式对象的通信等大多数具有相同的基本处理流程: 读取请求数据 - read 按协议解析请求 - decode…
第一章:手动搭建I/O网络通信框架1:Socket和ServerSocket入门实战,实现单聊 第二章:手动搭建I/O网络通信框架2:BIO编程模型实现群聊 在第二章中用BIO编程模型,简单的实现了一个聊天室.但是其最大的问题在解释BIO时就已经说了:ServerSocket接收请求时(accept()方法).InputStream.OutputStream(输入输出流的读和写)都是阻塞的.还有一个问题就是线程池,线程多了,服务器性能耗不起.线程少了,在聊天室这种场景下,让用户等待连接肯定不可取…
Doug Lea 在 Scalable IO in Java 的 PPT 中描述了 Reactor 编程模型的思想,大部分 NIO 框架和一些中间件的 NIO 编程都与它一样或是它的变体.本文结合 PPT 按照自己的理解整理而来,最终编写了一个简单的 NIO 回显服务. Reactor 之所以高效是因为采用了分而治之和事件驱动的设计.大部分网络服务像 Web 服务器.分布式对象的通信等大多数具有相同的基本处理流程: 读取请求数据 - read 按协议解析请求 - decode 业务处理 - pr…
先来看看我们的server端: 创建一个serversocket,进行监听,每来一个客户端,就启动一个新启动为其服务: private void createListenSocket() { //如果创建监听socket的时候发生异常,将会隔WAIT_TIME毫秒重试,直到成功 while (true){ try { serverSocket = new ServerSocket(LISTEN_PORT); Log.info(创建监听socket成功,正在监听...); break; } cat…
NIO线程模型 什么是NIO线程模型? 上图是NIO的线程模型,  基于select实现,   这种线程模型的特点:  多条channel通过一个选择器和单挑线程绑定, 并且在这种编程模型中, Channel中相关业务逻辑不允许存在耗时的任务 , 如果一定会有耗时的逻辑, 请将它们放置到线程池中去运行,  因为这种模型虽然做到了非阻塞, 但是他并不是真正的异步编程, 任何channel上的任何耗时的操作, 都会拖垮这个选择器, 进而拖垮整条线程 , 这也是为啥它会被称为 同步非阻塞 什么是同步?…
第一章:手动搭建I/O网络通信框架1:Socket和ServerSocket入门实战,实现单聊 第二章:手动搭建I/O网络通信框架2:BIO编程模型实现群聊 第三章:手动搭建I/O网络通信框架3:NIO编程模型,升级改造聊天室 上一章讲到的NIO编程模型比较主流,非常著名的Netty就是基于NIO编程模型的.这一章说的是AIO编程模型,是异步非阻塞的.虽然同样实现的是聊天室功能,但是实现逻辑上稍微要比NIO和BIO复杂一点.不过理好整体脉络,会好理解一些.首先还是讲讲概念: BIO和NIO的区别…
Java网络编程和NIO详解3:IO模型与Java网络编程模型 基本概念说明 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件设备的所有权限.为了保证用户进程不能直接操作内核(kernel),保证内核的安全,操作系统将虚拟空间划分为两部分,一部分为内核空间,一部分为用户空间.针对linux操作系统而言,将最高的1G字节(从虚拟地址…
我们首先需要澄清一个概念:NIO到底是什么的简称?有人称之为New I/O,因为它相对于之前的I/O类库是新增的,所以被称为New I/O,这是它的官方叫法.但是,由于之前老的I/O类库是阻塞I/O,New I/O类库的目标就是要让Java支持非阻塞I/O,所以,更多的人喜欢称之为非阻塞I/O(Non-block I/O),由于非阻塞I/O更能够体现NIO的特点. 与Socket类和ServerSocket类相对应,NIO也提供了SocketChannel和ServerSocketChannel…
术语概念描述: IO有内存IO.网络IO和磁盘IO三种,通常我们说的IO指的是后两者. 阻塞和非阻塞,是函数/方法的实现方式,即在数据就绪之前是立刻返回还是等待. 以文件IO为例,一个IO读过程是文件数据从磁盘→内核缓冲区→用户内存的过程.同步与异步的区别主要在于数据从内核缓冲区→用户内存这个过程需不需要用户进程等待.有个数据拷贝的过程,是拷贝完再通知还是在内核缓冲区就通知.(网络IO把磁盘换做网卡即可) Linux IO模型 同步阻塞 同步非阻塞 IO复用 信号驱动 异步非阻塞 同步阻塞 去餐…